# DEVICE AND METHOD FOR GENERATING GRAPHIC INFORMATION, IMAGE PROCESSOR, INFORMATION PROCESSOR AND RECORDING MEDIUM

Patent number:

JP2001331812

**Publication date:** 

2001-11-30

Inventor:

ITO TAKESHI

Applicant:

**SONY CORP** 

Classification:

- international:

G06F17/17; G06T17/30: G06F17/17: G06T17/30:

(IPC1-7): G06T17/30; G06F17/17

- european:

Application number: JP20000146673 20000518 Priority number(s): JP20000146673 20000518

Report a data error here

#### Abstract of JP2001331812

PROBLEM TO BE SOLVED: To make it possible to generate vertex coordinates values for representing graphics such as n-th order Bezir curve and Bezier curved surface with hardware. SOLUTION: When four control points are given in u and v directions in a grid shape and the vertex coordinates values for representing an n-th order cured surface are generated from the grid-like control points, this graphic information generating device is provided with a linear interpolator 1 which sequentially operates A× (1-t)+B× t about the coordinates values of a new control point that internally divides a line between control points on the basis of the coordinates values A and B of the control points of prescribed bit width and an interpolation coefficient t having 0<=t<=1 with the prescribed bit width. For instance, the coordinates values of a vertex P0 of a 3rd order curved surface graphic is calculated by respectively and sequentially operating A× (1t)+B× t about a part between two respective control points adjoining in the u and v directions to calculate the coordinates values of 3× 4 pieces, 2× 4 pieces and 2× 3 pieces of new control points and finally calculating the coordinates values of 2× 2 pieces of new control points.

# 第1の実施形態としての図形情報生成装置 10の構成例



Data supplied from the esp@cenet database - Worldwide

#### (19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号 特開2001-331812 (P2001-331812A)

(43)公開日 平成13年11月30日(2001.11.30)

| (51) Int.Cl. <sup>7</sup> | 識別記号 | FΙ         | テーマコード(参考) |
|---------------------------|------|------------|------------|
| G06T 17/30                |      | G06T 17/30 | 5 B 0 5 6  |
| G06F 17/17                |      | G06F 17/17 | 5 B 0 8 0  |

#### 審査請求 未請求 請求項の数23 〇1. (全 30 頁)

|          |                             | 審査請求 未請求 請求項の数23 OL (全 30 頁                                                                                                                                               |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (21)出願番号 | 特願2000-146673(P2000-146673) | (71)出願人 000002185 ソニー株式会社                                                                                                                                                 |
| (22)出願日  | 平成12年5月18日(2000.5.18)       | 東京都品川区北品川6丁目7番35号                                                                                                                                                         |
|          |                             | (72)発明者 伊藤 豪<br>東京都港区赤坂 7-1-1 株式会社ソニー・コンピュータエンタテインメント内<br>(74)代理人 100090376<br>弁理士 山口 邦夫 (外1名)<br>Fターム(参考) 5B056 BB53 HH01 HH03<br>5B080 AA06 AA11 AA13 DA07 DA08<br>FA16 |
|          |                             |                                                                                                                                                                           |
|          |                             |                                                                                                                                                                           |

#### (54) 【発明の名称】 図形情報生成装置、画像処理装置、情報処理装置、図形情報生成方法及び記録媒体

#### (57)【要約】

【課題】 n次のベジエ曲線やベジエ曲面などの図形を表現する頂点の座標値をハードウエアにより生成できるようにする。

【解決手段】 u方向に4個の制御点及びv方向に4個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現するための頂点の座標値を生成する場合に、所定のビット幅の制御点の座標値A,Bと、所定のビット幅で0  $\leq$  t  $\leq$  1 の値をとる補間係数 t とに基づき、制御点間を内分する新たな制御点の座標値に関してA×(1-t)+B×tを順次演算する線形補間器 1 を備えるものである。例えば、u及びv方向で隣接する各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算して3×4個、2×4個、2×3個の新たな制御点の座標値を求め、最終的に2×2個の新たな制御点の座標値を求めることにより、3次の曲面図形の頂点P0の座標値を求めるようになされる。

#### 第1の実施形態としての図形情報生成装置 10の構成例



#### 【特許請求の範囲】

【請求項1】 水平方向に(n+1 [ただし、 $n \ge 2$  ])個の制御点及び垂直方向に(n+1)個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現するための頂点の座標値を生成する装置であって、所定のビット幅の制御点の座標値A,B と、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数 t とに基づき、前記制御点間を内分する新たな制御点の座標値に関して $A \times (1-t) + B \times t$  を順次演算する線形補間器を備え

【請求項2】 前記線形補間器には、浮動小数点又は固定小数点で示される各々の制御点の座標値A, Bが与えられることを特徴とする請求項」に記載の図形情報生成装置。

【請求項3】 前記線形補間器は、

ることを特徴とする図形情報生成装置。

前記制御点の座標値A, Bの指数部の大きい方に桁を合わせる桁合わせ部と、

前記桁合わせ部による桁合わせ後の値Aと補間係数(1-t)とを乗算する第1の乗算器と、

前記桁合わせ部による桁合わせ後の値Bと補正係数tと を乗算する第2の乗算器と、

前記第1の乗算器の出力と第2の乗算器の出力とを加算する加算器と、

前記加算器の出力を浮動小数点で示される所定のビット幅の座標値に正規化する正規化部とを有することを特徴とする請求項1に記載の図形情報生成装置。

【請求項4】 前記線形補間器は、

前記水平方向で隣接する各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$ を順次演算して $n \times (n+1)$  個の新たな制御点の座標値を求め、更に前記水平方向で隣接する新たな各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$ を順次演算することにより、最終的に $2 \times (n+1)$  個の新たな制御点の座標値を求め、

その後、前記垂直方向で隣接する各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$  を順次演算して $2 \times n$  個の新たな制御点の座標値を求め、更に前記垂直方向で隣接する新たな各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$  を順次演算することにより、最終的に $2 \times 2$  個の新たな制御点の座標値を求め、その後、前記水平方向及び垂直方向に関して前記 $2 \times 2$  個の制御点間について、それぞれ $A \times (1-t) + B \times t$  を順次演算し、前記頂点の座標値を求めることを特徴とする請求項1 に記載の図形情報生成装置。

【請求項5】 前記線形補間器は、

前記2×2個の新たな制御点の座標値から前記頂点の水平方向に接線ベクトル及び垂直方向に接線ベクトルを抽出し.

前記水平方向及び垂直方向に接線ベクトルに基づいて前記頂点における法線ベクトルを求めることを特徴とする

請求項1に記載の図形情報生成装置。

【請求項6】 水平方向に(n+1[ただし、n≥2]) 個の制御点及び垂直方向に(n+1)個の制御点を格子 状に与え、この格子状の制御点から生成されたn次の曲 面図形を画像処理する装置であって、

前記制御点の座標値を記憶する記憶装置と、

前記記憶装置から読み出した制御点の座標値に基づいて 前記 n 次の曲線図形及び曲面図形を表現するための頂点 の座標値を生成する図形情報生成装置とを備え、

10 前記図形情報生成装置は、

所定のビット幅の制御点の座標値A、Bと、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数 t とに基づき、前記制御点間を内分する新たな制御点の座標値に関してA $\times$ (1-t)+B $\times$ t を順次演算する線形補間器を有することを特徴とする画像処理装置。

【請求項7】 前記線形補間器には、浮動小数点又は固定小数点で示される各々の制御点の座標値A, Bが与えられることを特徴とする請求項6に記載の画像処理装置。

20 【請求項8】 前記線形補間器は、

前記制御点の座標値A, Bの指数部の大きい方に桁を合わせる桁合わせ部と、

前記桁合わせ部による桁合わせ後の値Aと補間係数(1-t)とを乗算する第1の乗算器と、

前記桁合わせ部による桁合わせ後の値Bと補正係数 t とを乗算する第2の乗算器と、

前記第1の乗算器の出力と第2の乗算器の出力とを加算 する加算器と、

前記加算器の出力を浮動小数点で示される所定のビット 個の座標値に正規化する正規化部とを有することを特徴 とする請求項6に記載の画像処理装置。

【請求項9】 前記線形補間器は、

前記水平方向で隣接する各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$  を順次演算して $n \times (n+1)$  個の新たな制御点の座標値を求め、更に前記水平方向で隣接する新たな各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$  を順次演算することにより、最終的に $2 \times (n+1)$  個の新たな制御点の座標値を求め、

40 その後、前記垂直方向で隣接する各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算して2×n個の新たな制御点の座標値を求め、更に前記垂直方向で隣接する新たな各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算することにより、最終的に2×2個の新たな制御点の座標値を求め、その後、前記水平方向及び垂直方向に関して前記2×2個の制御点間について、それぞれA×(1-t)+B×tを順次演算し、前記頂点の座標値を求めることを特徴とする請求項6に記載の画像処理装置。

【請求項10】 前記線形補間器は、

前記2×2個の新たな制御点の座標値から前記頂点の水平方向に接線ベクトル及び垂直方向に接線ベクトルを抽出し、

前記水平方向及び垂直方向に接線ベクトルに基づいて前 記頂点における法線ベクトルを求めることを特徴とする 請求項6に記載の画像処理装置。

【請求項11】 水平方向に(n+1[ただし、n≥2]) 個の制御点及び垂直方向に(n+1) 個の制御点を格子状に与え、この格子状の制御点から生成されたn次の曲面図形を外部からの操作情報に基づいて情報処理 10をする装置であって、

前記制御点の座標値を記憶する記憶装置と、

前記記憶装置から読み出した制御点の座標値に基づいて 前記n次の曲面図形を画像処理する画像処理装置と、

前記画像処理装置を制御するための操作情報を入力するように操作される操作部と、

前記操作部による操作情報に基づいて前記記憶装置から 読み出した曲面図形を変化させるように表示制御する制 御装置とを備え、

前記画像処理装置は、

所定のビット幅の制御点の座標値A,Bと、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数(1-t)とに基づき、前記制御点間を内分する新たな制御点の座標値に関して $A \times (1-t) + B \times t$ を順次演算する線形補間器を有することを特徴とする情報処理装置。

【請求項12】 前記制御点の座標値A, Bは各々浮動 小数点又は固定小数点で与えられることを特徴とする請求項11に記載の情報処理装置。

【請求項13】 前記線形補間器は、

前記制御点の座標値A、Bの指数部の大きい方に桁を合わせる桁合わせ部と

前記桁合わせ部による桁合わせ後の値Aと補間係数(1-t)とを乗算する第1の乗算器と、

前記桁合わせ部による桁合わせ後の値Bと補正係数 t とを乗算する第2の乗算器と、

前記第1の乗算器の出力と第2の乗算器の出力とを加算 する加算器と、

前記加算器の出力を浮動小数点で示される所定のビット 幅の座標値に正規化する正規化部とを有することを特徴 とする請求項11に記載の情報処理装置。

【請求項14】 前記線形補間器は、

前記水平方向で隣接する各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$ を順次演算して $n \times (n+1)$  個の新たな制御点の座標値を求め、更に前記水平方向で隣接する新たな各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$ を順次演算することにより、最終的に $2 \times (n+1)$  個の新たな制御点の座標値を求め、

その後、前記垂直方向で隣接する各々2つの制御点間に ついてそれぞれA×(1-t)+B×tを順次演算して 2×n個の新たな制御点の座標値を求め、更に前記垂直方向で隣接する新たな各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算することにより、最終的に2×2個の新たな制御点の座標値を求め、その後、前記水平方向及び垂直方向に関して前記2×2個の制御点間について、それぞれA×(1-t)+B×tを順次演算し、前記頂点の座標値を求めることを特徴とする請求項11に記載の情報処理装置。

【請求項15】 前記線形補間器は、

5 前記2×2個の新たな制御点の座標値から前記頂点の水平方向に接線ベクトル及び垂直方向に接線ベクトルを抽出し、

前記水平方向及び垂直方向に接線ベクトルに基づいて前 記頂点における法線ベクトルを求めることを特徴とする 請求項11に記載の情報処理装置。

【請求項16】 水平方向に(n+1[ただし、n≥2]) 個の制御点及び垂直方向に(n+1) 個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現するための頂点の座標値を生成する方法であって、

所定のビット幅の $(n+1) \times (n+1)$  個の制御点の 座標値を入力すると共に、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数(1-t) を入力し、

隣接する各々2つの前記制御点の座標値をA、Bとしたとき、

前記水平方向で隣接する各々2つの制御点間について、それぞれ $A \times (1-t) + B \times t$ を順次演算して $n \times (n+1)$  個の新たな制御点の座標値を求め、更に前記水平方向で隣接する新たな各々2つの制御点間についてそれぞれ $A \times (1-t) + B \times t$ を順次演算するととにより、最終的に $2 \times (n+1)$  個の新たな制御点の座標値を求め、

その後、前記垂直方向で隣接する各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算して2×n個の新たな制御点の座標値を求め、更に前記垂直方向で隣接する新たな各々2つの制御点間についてそれぞれA×(1-t)+B×tを順次演算することにより、最終的に2×2個の新たな制御点の座標値を求め、その後、前記水平方向及び垂直方向に関して前記2×240個の制御点間について、それぞれA×(1-t)+B×tを順次演算し、前記頂点の座標値を求めることを特徴とする図形情報生成方法。

【請求項17】 前記制御点の座標値A, Bは各々浮動 小数点又は固定小数点で与えられることを特徴とする請求項16に記載の図形情報生成方法。

【請求項18】 前記制御点の座標値A, Bが各々浮動 小数点で与えられる場合であって、

前記制御点の座標値A, Bの指数部の大きい方に桁を合わせ、

50 桁合わせ後の座標値Aと補間係数(1-t)とを乗算す

ると共に、桁合わせ後の座標値Bと係数tとを乗算し、 その後、乗算結果を加算した後の加算値を浮動小数点で 示される所定のビット幅の座標値に正規化することを特 徴とする請求項16に記載の図形情報生成方法。

【請求項19】 前記頂点の座標値を求める際に、 前記2×2個の新たな制御点の座標値から前記頂点の水 平方向に接線ベクトル及び垂直方向に接線ベクトルを抽 出し、

前記水平方向及び垂直方向に接線ベクトルに基づいて前 記頂点における法線ベクトルを求めることを特徴とする 10 請求項16に記載の図形情報生成方法。

【請求項20】 水平方向に(n+1[ただし、n≥ 2]) 個の制御点及び垂直方向に(n+1) 個の制御点 を格子状に与え、この格子状の制御点からn次の曲面図 形を表現するための頂点の座標値を生成する制御手順を 記録した記録媒体であって、

前記記録媒体には、

少なくとも、所定のビット幅の $(n+1) \times (n+1)$ 個の制御点の座標値を入力すると共に、所定のビット幅 で0 ≤ t ≤ 1の値をとる補間係数 (1-t) を入力し、 隣接する各々2つの前記制御点の座標値をA、Bとした とき、

前記水平方向で隣接する各々2つの制御点間について、 それぞれA×(1-t)+B×tを順次演算してn× (n+1)個の新たな制御点の座標値を求め、更に前記 水平方向で隣接する新たな各々2つの制御点間について それぞれ $A \times (1 - t) + B \times t$ を順次演算することに より、最終的に2×(n+1)個の新たな制御点の座標 値を求め、

その後、前記垂直方向で隣接する各々2つの制御点間に ついてそれぞれA×(1-t)+B×tを順次演算して 2×n個の新たな制御点の座標値を求め、更に前記垂直 方向で隣接する新たな各々2つの制御点間についてそれ ぞれA×(1-t)+B×tを順次演算することによ り、最終的に2×2個の新たな制御点の座標値を求め、 その後、前記水平方向及び垂直方向に関して前記2×2 個の制御点間について、それぞれ $A \times (1 - t) + B \times$ **t を順次演算し、前記頂点の座標値を求めるような制御** 手順が記録されることを特徴とする記録媒体。

【請求項21】 前記制御点の座標値A, Bは各々浮動 小数点又は固定小数点で与えられることを特徴とする請 求項20に記載の記録媒体。

【請求項22】 前記制御点の座標値A, Bが各々浮動 小数点で与えられる場合であって、

前記記録媒体には、

前記制御点の座標値A、Bの指数部の大きい方に桁を合 わせ、

析合わせ後の座標値Aと補間係数(1-t)とを乗算す ると共に、桁合わせ後の座標値Bと補正係数tとを乗算 点で示される所定のビット幅の座標値に正規化するよう な制御手順が記録されることを特徴とする請求項21に 記載の記録媒体。

【請求項23】 前記記録媒体には、

前記頂点の座標値を求めるに当たって、

前記2×2個の新たな制御点の座標値から前記頂点の水 平方向に接線ベクトル及び垂直方向に接線ベクトルを抽 出し、

前記水平方向及び垂直方向に接線ベクトルに基づいて前 記頂点における法線ベクトルを求めるような制御手順が 記録されることを特徴とする請求項20に記載の記録媒 体。

【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、n次のベジェ曲線 やベジエ曲面などの図形情報を取り扱うCAD及びCA Mシステムを導入したエンタテインメント装置や、携帯 用ゲーム機、携帯端末装置、携帯電話機などに適用して 好適な図形情報生成装置、画像処理装置、情報処理装 20 置、図形情報生成方法及び記録媒体に関するものであ る。

[0002]

30

【従来の技術】近年の情報処理分野ではCAD(comput er aided drawing) システムやCAM (computer aided manufacturing) システムなどを利用した画像処理装置 や情報処理装置などが多くなってきた。この種の処理装 置では、自由曲線や自由曲面をそれぞれ作成するための 表現方法としてベジエ(Bezier)曲線やベジエ曲面が利 用される場合が多い。

【0003】とのベジエ曲線の場合、周知のように(n +1)個の制御点を与えることによって作成された曲線 は、n次のベジエ曲線と言われる。また(n+1)× (n+1)個の制御点を与えることによって作成された 曲面は、n次ベジエ曲面と言われる。このうちベジエ曲 線は制御の容易性などから3次ベジエ曲線が利用される ことが多い。ベジエ曲面も同様の理由から(4×4)個 の制御点で表現される3次ベジエ曲面が多用されてい る。

【0004】図29及び図30は従来例に係る3次ベジ エ曲線の例(その1、2)を示す図である。図29に示 す3次ベジエ曲線は4つの制御点p0~p3の座標値を 用いて自由曲線を表現するものである。4 つの制御点 p 0~p3が与えられたとき、パラメータ(影響パラメー タ;0≦ t ≦1) tを与えておくことによって一義的に ベジエ曲線Rが決定される。3次ベジエ曲線は次式で表

 $[0005]R(t)=(1-t)^3p0+3t(1-t)^2p$  $1 + 3 t^{2}(1 - t)p2 + t^{3}p3$ 

ここに、制御点p0~p3は何れも位置ベクトルであ し、その後、乗算結果を加算した後の加算値を浮動小数 50 り、位置座標(x,y,z)の成分を有している。制御

点pO~p3のうち曲線が通過する点pOやp3は端点 (通過点)と呼称され、その他の制御点p1やp2は内 部制御点と呼称される場合がある。

【0006】そして、図30に示すように複数の端点、 例えばp0~p6を与えることによって、滑らかな自由 曲線を作成することができる。2つの端点によって形成 される最少構成要素の曲線をセグメントといい、(n+ 1)×(n+1)個の制御点を与えることによって作成 された最少構成要素の曲面(矩形)をバッチという。

【0007】図31は(4×4)個の制御点によって構 10 成されるパッチPBの具体例を示している。複数のパッ チを連ねると、図32に示すような3次のベジエ曲面を 形成することができる。このような3次のベジエ曲面を 取り扱う情報処理装置では、例えば、図32に示す乙方 向に曲面を変化させるような画像処理が施される。この 画像処理によって、3次のベジエ曲面を自由に変形する ことができる。

#### [0008]

【発明が解決しようとする課題】ところで、従来方式の ディスクトップ型やノート型といった大型の情報処理装 20 置によれば、自由曲線や曲面を表現するときに、浮動小 数点の積算器と加算器とを用いて3次のベジエ曲線やベ ジエ曲面の頂点の座標値計算などを行っていた。

【0009】しかしながら、この種の積算器は非常に回 路規模が大きいものであり、これを携帯電話機や、携帯 用のゲーム機などに適用しようとした場合に、チップサ イズの増大から携帯端末装置のコンパクト化の妨げとな ったり、そのコストアップを招くことになる。従って、 携帯端末装置で3次のベジエ曲線やベジエ曲面の頂点の 座標値を処理しようとした場合にソフトウェアに頼わざ るを得なくなるが、その場合に、演算速度が遅くなって 十分な性能を得ることができないという問題がある。

【0010】また、従来方式のハードウエアによる方式 では、光源計算などのライティング処理に必要な頂点の 法線ベクトルに関して、一度生成された頂点の座標値を 再び使用して計算し直すので、正確な法線ベクトルを算 出することが困難になったり、無断な演算時間が増加 し、引いては全体の情報処理の高速化の妨げとなるとい う問題がある。

を解決したもので、n次のベジエ曲線やベジエ曲面など の図形を表現する場合に、ソフトウエアに依存すること なく、これらの図形を表現する頂点の座標値をハードウ エアにより生成できるようにした図形情報生成装置、画 像処理装置、情報処理装置、図形情報生成方法及び記録 媒体などを提供するものである。

#### [0012]

【課題を解決するための手段】上述した課題は、水平方 向に(n+1[ただし、n≥2]) 個の制御点及び垂直方 向に(n+1)個の制御点を格子状に与え、この格子状 50 であって、これらの制御点の座標値を記憶する記憶装置

の制御点からn次の曲面図形を表現するための頂点の座 標値を生成する装置であって、所定のビット幅の制御占 の座標値A, Bと、所定のビット幅で0≤t≦1の値を とる補間係数tとに基づき、制御点間を内分する新たな 制御点の座標値に関してA×(1-t)+B×tを順次 演算する線形補間器を備えることを特徴とする図形情報 生成装置によって解決される。

【0013】本発明に係る図形情報生成装置によれば、 水平方向に(n+1)個の制御点及び垂直方向に(n+ 1) 個の制御点を格子状に与え、この格子状の制御点か らn次の曲面図形を表現する場合に、例えば、各々浮動 小数点で示される所定のビット幅の(n+1)×(n+ 1)個の制御点の座標値と、所定のビット幅で0≦t≦ 1の値をとる補間係数 t とを線形補間器に入力すると、 との線形補間器では、隣接する各々2つの制御点の座標 値をA、Bとしたとき、この水平方向で隣接する各々2 つの制御点間について、それぞれA×(1-t)+B× tを順次演算してn×(n+1)個の新たな制御点の座 標値を求め、更に水平方向で隣接する新たな各々2つの 制御点間についてそれぞれA×(1-t)+B×tを順 次演算することにより、最終的に2×(n+1)個の新 たな制御点の座標値を求め、その後、垂直方向で隣接す る各々2つの制御点間についてそれぞれA×(1-t) +B×tを順次演算して2×n個の新たな制御点の座標 値を求め、更に垂直方向で隣接する新たな各々2つの制 御点間についてそれぞれA×(1-t)+B×tを順次 演算することにより、最終的に2×2個の新たな制御点 の座標値を求め、その後、水平方向及び垂直方向に関し て2×2個の制御点間について、それぞれA×(1t)+B×tを順次演算し、頂点の座標値を求めるよう

【0014】従って、ソフトウエアに依存するところを 少なくすることができ、n次のベジエ曲線やベジエ曲面 を表現する上位所定ビット幅の頂点の座標値をハードウ エアにより高速に得ることができる。しかも、2×2個 の新たな制御点の座標値から頂点の接線ベクトルを抽出 することにより、ライティング処理に必要な法線ベクト ルを生成することができる。

【0015】また、桁合わせ部、乗算器、加算器及び正 【0011】そこで、この発明はこのような従来の課題 40 規化部といった小規模な回路構成によって線形補間器を 実現できるので、高性能かつ低消費電力動作が可能な図 形情報生成装置を提供することができる。これにより、 当該図形情報生成装置をベジエ曲面などの画像処理を行 う画像処理装置、特に消費電力が制限される携帯端末装 置などの情報処理装置に十分応用することができる。

> 【0016】本発明に係る画像処理装置は、水平方向に (n+1[ただし、n≥2]) 個の制御点及び垂直方向に (n+1)個の制御点を格子状に与え、この格子状の制 御点から生成されたn次の曲面図形を画像処理する装置

と、この記憶装置から読み出した制御点の座標値に基づいてn次の曲面図形を表現するための頂点の座標値を生成する図形情報生成装置とを備え、この図形情報生成装置は所定のビット幅の制御点の座標値A、Bと、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数 t とに基づき、制御点間を内分する新たな制御点の座標値に関して $A \times (1-t) + B \times t$  を順次演算する線形補間器を有することを特徴とするものである。

【0017】本発明に係る画像処理装置によれば、上述した図形情報生成装置が応用されるので、ソフトウエアに依存するところを少なくすることができる。n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値を用いてハードウエアにより高速に画像処理を行うことができる。

【0018】従って、図形情報生成装置を構成する線形補間器を小規模な回路構成によって実現できるので、高性能かつ低消費電力動作が可能な画像処理装置を提供することができる。

【0019】本発明に係る情報処理装置は、水平方向に (n+1[ただし、n≥2]) 個の制御点及び垂直方向に (n+1)個の制御点を格子状に与え、この格子状の制 御点から生成されたn次の曲面図形を外部からの操作情 報に基づいて情報処理をする装置であって、これらの制 御点の座標値を記憶する記憶装置と、この記憶装置から 読み出した制御点の座標値に基づいてn次の曲面図形を 画像処理する画像処理装置と、この画像処理装置を制御 するための操作情報を入力するように操作される操作部 と、この操作部による操作情報に基づいて記憶装置から 読み出した曲面図形を変化させるように表示制御する制 御装置とを備え、画像処理装置は所定のビット幅の制御 点の座標値A、Bと、所定のビット幅で0≤t≤1の値 をとる補間係数tとに基づき、制御点間を内分する新た な制御点の座標値に関して $A \times (1-t) + B \times t$ を順 次演算する線形補間器を有することを特徴とするもので ある。

【0020】本発明に係る情報処理装置によれば、上述した画像図形情報生成装置が画像処理装置に応用されるので、ソフトウエアに依存するところが少なくなり、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値を外部からの操作情報に基づいてハードウエアにより高速に情報処理することができる。

【0021】従って、画像処理装置を構成する線形補間器を小規模な回路構成によって実現できるので、高性能かつ低消費電力動作が可能な、特に携帯端末装置などの情報処理装置を提供することができる。

【0022】本発明に係る図形情報生成方法は、水平方向に (n+1[ただし、 $n \ge 2]$ )個の制御点及び垂直方向に (n+1) 個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現するための頂点の座標値を生成する方法であって、所定のビット幅の (n+1)

1)×(n+1)個の制御点の座標値を入力すると共 に、所定のビット幅で0≤t≤1の値をとる補間係数 t を入力し、隣接する各々2つの制御点の座標値をA, B としたとき、との水平方向で隣接する各々2つの制御点 間について、それぞれA×(1-t)+B×tを順次演 算してn×(n+1)個の新たな制御点の座標値を求 め、更に水平方向で隣接する新たな各々2つの制御点間 についてそれぞれA×(1-t)+B×tを順次演算す ることにより、最終的に2×(n+1)個の新たな制御 点の座標値を求め、その後、垂直方向で隣接する各々2 つの制御点間についてそれぞれAx(1-t)+Bxt を順次演算して2×n個の新たな制御点の座標値を求 め、更に垂直方向で隣接する新たな各々2つの制御点間 についてそれぞれA×(1-t)+B×tを順次演算す ることにより、最終的に2×2個の新たな制御点の座標 値を求め、その後、水平方向及び垂直方向に関して2× 2個の制御点間について、それぞれA×(1-t)+B ×tを順次演算し、頂点の座標値を求めることを特徴と するものである。

20 【0023】本発明に係る図形情報生成方法によれば、ソフトウエアに依存するところが少なくなり、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値をハードウエアにより高速に得ることができる。しかも、この方法によって実現化される図形情報生成装置や、画像処理装置、情報処理装置などにおいて、小規模な回路構成にまとめられた線形補間器を使用することができる。

【0024】本発明に係る記録媒体は、水平方向に(n + 1 [ただし、n ≥ 2]) 個の制御点及び垂直方向に (n +1)個の制御点を格子状に与え、この格子状の制御点 からn次の曲面図形を表現するための頂点の座標値を生 成する制御手順を記録した記録媒体であって、との記録 媒体には少なくとも、所定のビット幅の(n+1)× (n+1)個の制御点の座標値を入力すると共に、所定 のビット幅で0≦t≦1の値をとる補間係数tを入力 し、隣接する各々2つの制御点の座標値をA、Bとした とき、この水平方向で隣接する各々2つの制御点間につ いて、それぞれA×(1-t)+B×tを順次演算して n×(n+1)個の新たな制御点の座標値を求め、更に 水平方向で隣接する新たな各々2つの制御点間について それぞれA×(1-t)+B×tを順次演算することに より、最終的に2×(n+1)個の新たな制御点の座標 値を求め、その後、垂直方向で隣接する各々2つの制御 点間についてそれぞれA×(1-t)+B×tを順次演 算して2×n個の新たな制御点の座標値を求め、更に垂 直方向で隣接する新たな各々2つの制御点間についてそ れぞれ $A \times (1 - t) + B \times t$ を順次演算することによ り、最終的に2×2個の新たな制御点の座標値を求め、 その後、水平方向及び垂直方向に関して2×2個の制御 点間について、それぞれA×(1-t)+B×tを順次

演算し、頂点の座標値を求めるような制御手順が記録されることを特徴とするものである。

【0025】本発明に係る記録媒体によれば、図形情報生成装置や、画像処理装置、情報処理装置などに内蔵される線形補間器を記録媒体に記録された制御手順に基づいて再現性良く制御できるので、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値をハードウエアにより高速に発生させることができる。

【0026】従って、ベジエ曲線やベジエ曲面などの図形情報を取り扱うCAD及びCAMシステムを導入した。10エンタテインメント装置や、携帯用ゲーム機、携帯端末装置及び携帯電話機などに十分利用することができる。【0027】

【発明の実施の形態】との発明に係る図形情報生成装置、画像処理装置、情報処理装置、図形情報生成方法及び記録媒体の一実施の形態について、図面を参照しながら説明をする。

【0028】(1)第1の実施形態

[図形情報生成装置] 図1 は本発明に係る実施形態としての図形情報生成装置10の構成例を示すブロック図で 20 ある。図2 は頂点の座標値生成時の(n+1)×(n+1)個の制御点p0~pn(n+2)の配置例を示す図である。

【0029】この実施形態では、水平方向に(n+1)個の制御点及び垂直方向に(n+1)個の制御点を格子状に与え、この格子状の制御点からn次のベジエ曲面などの図形を表現する場合に、その図形の頂点の座標値を生成する線形補間器を備え、例えば各々浮動小数点で示される所定のビット幅の制御点の座標値A,Bと、所定のビット幅で0 $\le$ t $\le$ 1の値をとる補間係数 t とに基づき、制御点間を内分する新たな制御点の座標値に関してA×(1-t)+B×tを順次演算して、ソフトウエアに依存することなく、n次のベジエ曲線やベジエ曲面を表現する頂点の座標値をハードウエアにより高速に生成できるようにしたものである。

【0030】図1に示す図形情報生成装置10はn次のベジエ曲線やベジエ曲面を表現する頂点の座標値を生成するものであり、制御装置4、記憶媒体5及び図形情報生成部6を有している。この頂点の座標値は例えば、図2において、水平方向に(n+1[ただし、 $n \ge 2$ ])個の制御点 $p0\sim pn$ 及びその垂直方向に(n+1)個の制御点 $p0\sim pn$ (n+2) -nを格子状に与え、この格子状の $(n+1)\times(n+1)$ 個の制御点 $p0\sim pn$ (n+2) から生成されるものである。

【0031】との図形情報生成部6は図1に示す線形補間器1、メモリ部2及び制御点選択部3を有している。線形補間器1では制御装置4からの桁合わせ制御信号S1などを受けて所定のビット幅の制御点の座標値A,Bと、所定のビット幅で0≦t≦1の値をとる補間係数tとに基づき、制御点間を内分する新たな制御点の座標値

に関して(1)式を順次演算するようになされる。 $A \times (1-t) + B \times t \cdot \cdot \cdot \cdot (1)$ 

【0032】線形補間器1の出力段にはメモリ部2が接続され、順次演算された補間結果が制御装置4の書込み 読出し制御信号S2を受けて記憶され、次の演算に必要な制御点の座標値を順次読み出すように制御される。

【0033】この線形補間器1は例えば、2×2個の新たな制御点の座標値から頂点の座標値を演算するときに、その頂点の水平方向の接線ベクトルUout及びその垂直方向の接線ベクトルVoutを演算するようになされる。この2つのベクトルをメモリ部2から後段の画像処理装置などに出力するようになされる。これら2つの接線ベクトルUout及びVoutに基づいて頂点における法線ベクトルを求めるためである。法線ベクトルは明るさを演算するライティング処理などに利用される。

【0034】この線形補間器1の入力段には制御点選択部3が接続され、制御装置4からの切り換え制御信号S0を受けて初期の制御点の座標値A,B又は線形補間演算によって新たに発生した制御点の座標値CA,CBを選択するようになされる。制御装置4にはROMなどの記録媒体5が接続され、このROM情報に基づいて制御装置4は線形補間器1や、メモリ部2、制御点選択部3などの入出力を制御するようになされる。

【0035】この記録媒体5には少なくとも、所定のビ ット幅の(n+1)×(n+1)個の制御点の座標値を 入力すると共に、所定のビット幅で0≤t≤1の値をと る補間係数 t を入力し、隣接する各々2つの制御点の座 標値をA、Bとしたとき、この水平方向で隣接する各々 2つの制御点間について、それぞれ(1)式を順次演算 してn×(n+1)個の新たな制御点の座標値を求め、 更に水平方向で隣接する新たな各々2つの制御点間につ いてそれぞれ(1)式を順次演算することにより、最終 的に2×(n+1)個の新たな制御点の座標値を求め、 その後、垂直方向で隣接する各々2つの制御点間につい てそれぞれ(1)式を順次演算して2×n個の新たな制 御点の座標値を求め、更に垂直方向で隣接する新たな各 々2つの制御点間についてそれぞれ(1)式を順次演算 することにより、最終的に2×2個の新たな制御点の座 標値を求め、その後、水平方向及び垂直方向に関して2 ×2個の制御点間について、それぞれ(1)式を順次演 算し、頂点の座標値を求めるような制御手順が記録され る。

【0036】もちろん、この記録媒体5には、頂点の座標値を求めるに当たって、2×2個の新たな制御点の座標値から頂点の水平方向の接線ベクトル及び垂直方向の接線ベクトルを抽出し、その水平方向及び垂直方向の接線ベクトルに基づいて頂点における法線ベクトルを求めるような制御手順も記録されている。

【0037】これらの制御手順に基づいて制御装置4に 50 より線形補間器1を再現性良く制御できるので、n次の

ベジエ曲線やベジエ曲面を表現する上位所定ビット幅の 頂点の座標値をハードウエアにより発生させることができる。従って、ベジエ曲線やベジエ曲面などの図形情報 を取り扱うCAD及びCAMシステムを導入したエンタ テインメント装置や、携帯用ゲーム機、携帯端末装置、 携帯電話機などに当該図形情報生成装置10を十分利用 することができる。

【0038】続いて、線形補間器1の内部構成例について説明する。この例では線形補間器1には浮動小数点線形補間器(FL1P)が使用される。図3は浮動小数点 10の座標値のデータフォーマット例を示す図である。図3に示すデータフォーマット例によれば、各々の制御点の座標値は32ビットで与えられ、その1ビット目が符号部Sであり、次の8ビットが指数部Eであり、残りの23ビットが加数部Fである。各々の制御点の座標値をこれらの符号部S、指数部E及び加数部Fで示すと式(2)のようになる。

#### 1. $F \times 2^{(\mathfrak{t}-12)}$ $\cdot \cdot \cdot (2)$

【0039】この符号部Sでは座標値の正又は負が区別 され、指数部Eには8ビットで示される補間係数tが与 えられる。補間係数 t の値は0 ≤ t ≤ ] を採るが、例え ばO. 1刻みで(1-t)を演算するようなされる。と の例では指数計算を高速化するために、指数部EはO、 16, 32, 48, 64, 80, 96, 112, 128 の16刻みで計9個の整数により表現するようにした。 この場合に、t=0.5がE=64に相当する。加数部 Fは小数点以下を23ビットの2進数で表される。これ らはIEEE754で規定されているのでとれに従う。 【0040】図4は線形補間器1の内部構成例を示すブ ロック図である。図4に示す線形補間器1は各々の制御 点に関して浮動小数点で与えられる座標値A、Bに基づ いて補間演算するものである。線形補間器1の入力段に は桁合わせ部11が設けられ、制御点の所定のビット幅 の座標値A、Bの指数部Eの大きい方に桁を合わせるよ うになされる。桁合わせ部11にはシフトレジスタが使 用され、座標値A、Bの小さい方の指数部をシフトして 大きい方の指数部に揃えるようになされる。

【0041】 この桁合わせ部 1 1 には第 1 及び第 2 の乗算器 1 2、1 3 が接続される。乗算器 1 2 では桁合わせ後の値A'と補間係数(1-t)とが乗算され、乗算器 40 1 3 は桁合わせ後の値B'と補間係数 t とが乗算される。補間係数(1-t)は乗算器 1 2 の入力段に接続された減算器 1 4 により「1」から補正係数 t を減算して生成される。

【0042】 これらの乗算器 12, 13 には加算器 15 が接続され、乗算器 12 の出力 A'×(1-t)と乗算器 13 の出力 B×tとを加算するようになされる。加算器 15 には正規化部 16 が接続され、加算器 15 の出力 A'×(1-t)+B'×tを(2)式で示したような浮動小数点で所定のビット幅の座標値に正規化するよう

になされる。

【0043】従って、水平方向で隣接する各々2つの制 御点間についてそれぞれA´×(1-t)+B´×tを 順次演算して、n×(n+1)個の新たな制御点の座標 値を求め、更に水平方向で隣接する新たな各々2つの制 御点間についてそれぞれA′×(1-t)+B′×tを 順次演算することにより、最終的に2×(n+1)個の 新たな制御点の座標値を求め、その後、垂直方向で隣接 する各々2つの制御点間についてそれぞれA'×(1t) + B' × t を順次演算して  $2 \times n$  個の新たな制御点 の座標値を求め、更に垂直方向で隣接する新たな各々2 つの制御点間についてそれぞれ $A' \times (1-t) + B'$ ×tを順次演算することにより、最終的に2×2個の新 たな制御点の座標値を求め、その後、水平方向及び垂直 方向に関して2×2個の制御点間について、それぞれ  $A' \times (1-t) + B' \times t$ を順次演算することによ り、頂点の座標値を求めることができる。

【0044】続いて、図5~図10を参照しながら、図形情報生成装置10の動作例について説明をする。図5はU-V座標系における制御点p0~p15の配置例を示す図である。

【0045】との例ではn=3とした場合であって、図5に示すU-V座標系の水平方向(以下でu方向という)に4個の制御点及び垂直方向(以下でv方向という)に4個の制御点を格子状に与え、この4×4個の格子状の制御点p0~p15から例えば図6に示すような3次のベジエ曲面を表現するための頂点の座標値を生成する場合を想定する。

[0046] この図形情報生成装置10では23 ビット幅の $4\times4$  個の制御点 $p0\sim p15$  の座標値と、8 ビット幅で $0\le t\le 1$  の値をとる補間係数 t とが線形補間器1 に入力される。そして、隣り合う各々2 つの制御点の座標値をA、B としたとき、このu 方向で隣接する各々2 つの制御点間について、図7 A に示す $4\times4$  個の制御点 $p0\sim p15$  の座標値をそれぞれ(1)式で順次演算して図7 B に示すような $3\times4$  個の新たな制御点 $pu0\sim pu11$  の座標値を求める。

【0047】その後、図7Bに示した3×4個の制御点pu0~pu11の座標値を更にu方向で隣接する各々2つの制御点間について、それぞれ(1)式で順次演算して図9Aに示すような2×4個の新たな制御点pu0~pu7の座標値を求める。今度はv方向で隣接する各々2つの制御点間について、図8Aに示した2×4個の制御点pu0~pu7の座標値をそれぞれ(1)式で順次演算して図8Bに示すような2×3個の新たな制御点pv0~pv5の座標値を求める。

【0048】そして、図8Bに示した2×3個の制御点pv0~pv5の座標値を更にv方向で隣接する各々2つの制御点間について、それぞれ(1)式で順次演算して図10Aに示すような2×2個の新たな制御点pv0

~pv3の座標値を求める。その後、図9Aに示した2 ×2個の制御点間について、u方向及びv方向に関して それぞれ(1)式を順次演算し、図9Bに示すような2 ×2個の新たな制御点pp0~pp3の座標値を求め る。そして、図9Bに示した2×2個の新たな制御点p p0~pp3の座標値をu方向及びv方向に関してそれ ぞれ(1)式を順次演算し、図90に示すような頂点P 0の座標値を求めることを前提とする。

【0049】もちろん、記録媒体5に記録された制御手 順に基づいて、制御装置4は制御点の座標値A, Bの指 10 数部の大きい方に桁を合わせ、この桁合わせ後の座標値 Aと補間係数(1-t)とを乗算すると共に、桁合わせ 後の座標値Bと補正係数tとを乗算し、その後、乗算結 果を加算した後の加算値を浮動小数点で示される所定の ビット幅の座標値に正規化するようなされる。

【0050】これらを補間条件にして、図10のフロー チャートのステップA1で4×4個の制御点の座標値 が、記録媒体5の制御手順に従って、制御装置4の制御 を受けた線形補間器1に23ビット幅の4×4個の制御 点 $p \circ 0 \sim p \circ 15$ の座標値と、8 ビット幅で $0 \le t \le 1$ の 20 の座標値が求められる。 値をとる補間係数 t とが入力される。座標値の浮動小数 点の指数部Eは0、16、32、48、64、80、9\*

> pu[0] = FLIP(p[0], p[1], u);pu[1] = FLIP (p[1], p[2], u); pu[2] = FLIP(p[2], p[3], u); pu[3] = FLIP(p[4], p[5], u);pu[4] = FLIP(p[5], p[6], u):pu[5] = FLIP(p[6], p[7], u);pu [6] = FLIP (p [8], p [9], u); pu[7] = FLIP(p[9], p[10], u);pu[8] = FLIP (p[10], p[11], u); pu[9] = FLIP (p[12], p[13], u); pu[10] = FLIP (p[13], p[14], u);

この制御点pu0~pu11の座標値はメモリ部2に格 納される。ととで隣り合う各々2つの制御点の座標値を CA, CBとする。

【0054】その後、この座標値CA, CBがメモリ部 2から読み出され、これが制御装置4の切り換え制御を 受けた制御点選択部3により選択され、更にu方向で隣 40 が求められる。 接する各々2つの制御点間について、(1)式により補 間され、制御点pu0~pu11を12個から8個に減※

pu[11] = FLIP(p[14], p[15], u);

※らされる。ここで、(1)式に関して C = FLIP(CA, CB, u);

」と記述すると、u方向で隣接する各々2つの制御点間に ついて、それぞれ(4)式で順次演算して図8Aに示す ような2×4個の新たな制御点pu0~pu7の座標値

[0055]

pu[0] = FLIP(pu[0], pu[1], u);pu[1] = FLIP (pu[1], pu[2], u); pu [2] = FLIP (pu [3], pu [4], u); pu[3] = FLIP (pu[4], pu[5], u); pu [4] = FLIP (pu [6], pu [7], u); pu[5] = FLIP(pu[7], pu[8], u);pu [6] = FLIP (pu [9], pu [10], u);  $pu[7] = FLIP(pu[10], pu[11], u); \cdots (4)$ 

\*6、112、128である。

【0051】その後、ステップA2に移行してU座標を 初期設定をするために、その座標値がu=0に設定され る。そして、ステップA3に移行してu=128になっ たか否かが検出される。 u = 128になった場合には、 4×4個の制御点p0~p15による3次のベジエ曲面 の頂点座標値が得られる。u=128になっていない場 合には補間演算を継続するために、ステップA4に移行 する。 この u 方向に関して 1 つの頂点の座標値の生成に ついて9回の補間処理がなされる。

16

【0052】ステップA4ではu方向で隣接する各々2 つの制御点間について、(1)式により補間され、制御 点p0~p15を16個から8個に減らされる。例え ば、(1)式に関して

C=FLIP(A, B, u);

と記述すると、u方向で隣接する各々2つの制御点間に ついて、図7Aに示した4×4個の制御点p0~p15 の座標値がそれぞれ(2)式で順次演算され、図7Bに 示したような3×4個の新たな制御点pu0~pu11

[0053]

これらの座標値もメモリ部2に格納される。

【0056】その後、ステップA5に移行してV座標を 初期設定をするために、その座標値がv=0に設定され る。そして、ステップA6に移行してV座標についてv = 128になったか否かが検出される。 v = 128でV 座標における補間処理の1サイクルが終了するためであ る。従って、v=128でステップA11に移行する  $\beta$ , v = 0, 16, 32, 48, 64, 80, 96, 1 12の場合にはv方向の補間処理を継続するために、ス テップA7に移行する。 \*10

\*【0057】ステップA7ではv方向で隣接する各々2 つの制御点間について、(1)式により補間され、制御 点pu0~pu7を8個から4個に減らされる。例え ば、v方向で隣接する各々2つの制御点間について、図 8Aに示した2×4個の制御点pu0~pu7の座標値 CA, CBをそれぞれ(5)式で順次演算して図8Bに 示すような2×3個の新たな制御点pv0~pv5の座 標値が求められる。

[0058]

```
pv[0] = FLIP(pu[0], pu[2], v);
pv[1] = FLIP (pu[1], pu[3], v);
pv[2] = FLIP (pu[2], pu[4], v);
pv[3] = FLIP(pu[3], pu[5], v);
pv[4] = FLIP(pu[4], pu[6], v);
pv[5] = FLIP(pu[5], pu[7], v); \cdots (5)
```

【0059】これらの座標値もメモリ部2に格納され る。その後、同様な読出し制御を受けて、図9Bに示し た2×3個の制御点pv0~pv5の座標値を更にv方 向で隣接する各々2つの制御点間について、ステップA※20 【0060】

※8に移行して、それぞれ(6)式で順次演算して図9A に示すような2×2個の新たな制御点pv0~pv3の 座標値が求められる。

```
pv[0] = FLIP (pv[0], pv[2], v);
pv[1] = FLIP(pv[1], pv[3], v);
pv[2] = FLIP(pv[2], pv[4], v);
pv[3] = FLIP(pv[3], pv[5], v);
```

【0061】その後、ステップA8に移行して図9Aに 示した2×2個の制御点間について、u方向及びv方向 に関してそれぞれ(7)式を順次演算し、図9Bに示す★

★ような2×2個の新たな制御点pp0~pp3の座標値 が求められる。

```
pp[0] = FLIP(pv[0], pv[1], u);
pp[1] = FLIP(pv[2], pv[3], u);
pp[2] = FLIP(pv[0], pv[2], v);
pp[3] = FLIP(pv[1], pv[3], v); \cdots (7)
```

[0062]

【0063】そして、図9Bに示した2×2個の新たな 制御点pp0~pp3の座標値をステップA9に移行し てu方向及びv方向に関してそれぞれ(8)式を順次演☆

☆算し、図9Cに示すような頂点POの座標値が求められ る。

```
P0 = FLIP(pp[0], pp[1], v)
                                        \cdot \cdot \cdot (8)
```

【0064】なお、上式(2)~(8)はいずれもC言 語で記述したものである。その後、ステップA10に移 行してv方向の補間処理の粗さを調整するv=v+dv が演算される。ことでdvはベジエ曲面を表現するv方 向のパッチ面の分割数を粗くするか細かくするかを設定 40 粗くするか細かくするかを設定するための演算子であ するための演算子である。 d v は例えば16,8 などの 整数で与えられ、ととではパッチ面の分割数を細かくす るために 16 (粗) を 8 (密) に減ずるような v = v + d vを演算した後に、ステップA6に戻る。

【0065】ステップA6では同様な補間演算を<math>v=0~128の場合について行うために、V座標について v = 128になったか否かが検出される。つまり、1つの 頂点の座標値の生成についてu方向を1つ変化させる毎 に、とのv方向に関して9回の補間処理がなされる。従 って、v方向に関して9回の補間処理が終わると、ステ 50 【0067】その後、ステップA12に移行して与えら

ップA6でv=128となった場合に、ステップA11 に移行して、u方向の補間処理の粗さを調整するu=u+duが演算される。

【0066】ととでduはu方向のパッチ面の分割数を る。ととではパッチ面の分割数を細かくするために16 を8に減ずるようなu=u+duを演算した後に、ステ ップA3に戻る。ステップA3では同様な補間演算をu =0~128の場合について行うために、U座標につい Tu = 128になったか否かが検出される。u = 128になった場合には、9×9=81回の補間処理を経て4 ×4個の制御点p0~p15による3次のベジェ曲面の 1つの頂点座標値が得られ、その部分の補間演算を終了 する。

れた制御点について全て頂点座標値を生成したかが検出 される。例えば、制御装置4からの線形補間器1へ終了 コマンドが発行されることで、頂点座標値の生成処理を 終了する。終了コマンド検出されない場合には、ステッ プA1に戻って次の4×4個の制御点が入力され、上述 した処理が繰り返される。これにより、他の3次のベジ エ曲面の頂点座標値をハードウエアにより得ることがで きる。

【0068】[法線ベクトルの生成例]図11A~図1 1 Cは図形情報生成装置 1 0 による法線ベクトルの生成\*10 【0070】

```
* 例を示す遷移図である。この例では、図9 Bに示した2
 ×2個の新たな制御点pp0~pp3の座標値から頂点
 POのu方向の接線ベクトルu (上矢印を省略する)及
 び∨方向の接線ベクトル∨ (上矢印を省略する)が抽出
 され、この2つの接線ベクトルu, vに基づいて頂点P
 0における法線ベクトル2が求められる。
```

20

【0069】図11Aに示すu方向の接線ベクトルuは U座標のx成分をuxとし、そのy成分をuyとし、そ の z 成分を u z とすると、(9) により演算される。

```
u x = pp [3]. x - pp [2]. x;
uy = pp [3]. y - pp [2]. y;
uz = pp [3]. z - pp [2]. z;
```

※演算される。

[0072]

【0071】同様にして、図11Bに示すv方向の接線 ベクトルャはV座標のx成分をvxとし、そのy成分を Vyとし、その2成分をVzとすると、(10)により※

```
vx = pp[1].x - pp[0].x;
vy = pp[1]. y - pp[0]. y;
vz = pp [1]. z - pp [0]. z;
                                \cdots \cdots (10)
```

は、これら2つの接線ベクトルu, vの外積を演算した ものである。この法線ベクトルzは光色を算出するライ ティング処理に使用される。例えば、光源から照射され る光の向きを光源ベクトルとしたとき、この光源ベクト ルと法線ベクトルの内積が演算される。そして、光源ベ クトルと法線ベクトルとが一致したとき ( $\cos \theta = 1$ ) に、一番明るくなうように輝度を演算するようになされ

【0074】なお、頂点P0の接線ベクトルu、vは4 個の制御点の座標値が重なっていると、正確に接線ベク トルu, vを演算できないので、制御装置4内に比較器 などを設け、4個の制御点の座標値が重なているか否か を判別するようにするとよい。例えば、制御点の先頭の 2つの座標値と最後の2つの座標値を比較して一致して いるか否かを判別する。直線や球形に係る図形情報を生 成する場合に座標値が一致するからである。

【0075】このように、本発明に係る第1の実施形態 としての図形情報生成装置10によれば、u方向に4個 の制御点及び v 方向に 4 個の制御点を線形補間器 1 に与 えると、ソフトウエアに依存することなく、ハードウエ アによりこの制御点p0~p15から3次のベジエ曲面 を表現する頂点P0の座標値を生成することができる。 しかも、2×2個の新たな制御点pp0~pp3の座標 値から頂点POの接線ベクトルu、vを抽出できるの で、ライティング処理に必要な法線ベクトルzを生成す ることができる。

【0076】また、桁合わせ部11、乗算器12,1 3、加算器15及び正規化部16といった小規模な回路 構成によって線形補間器 1 を実現できるので、高性能か つ低消費電力動作が可能な図形情報生成装置10を提供

【0073】図11Cに示す頂点P0の法線ベクトルェ 20 することができる。これにより、当該図形情報生成装置 10をベジエ曲面などの画像処理を行う画像処理装置、 特に消費電力が制限される携帯端末装置などの情報処理 装置に十分応用することができる。

> 【0077】この例では制御点の座標値A、Bに関して 各々浮動小数点の場合について説明したが、これに限ら れることはなく、これらの座標値A、Bを固定小数点で 線形補間器1に与えてもよい。また、頂点の座標値は2 次元のU-V座標系で処理する場合について説明した が、もちろん、3次以上でも本発明を適用することがで きる。頂点の座標値もこの限りではない。ベジエ曲面に 限らずベジエ曲線や、3次だけでなくそれ以外の次数の ベジエ曲面に適用することができる。

> 【0078】[第1の画像処理装置]図12は本発明に 係る実施形態としての第1の画像処理装置100の構成 例を示すブロック図である。

【0079】との実施形態では、上述した図形情報生成 装置10が応用され、ソフトウエアに依存することな く、ハードウエアにより生成された上位所定ビット幅の 頂点の座標値を用いてn次のベジエ曲線やベジエ曲面を 画像処理するものである。

【0080】図12に示す画像処理装置100は図形情 報生成装置 10の主要部の一例となるベジェ分割装置 1 7を有しており、その図形情報生成部6によって生成さ れたn次の曲面図形を画像処理するものである。との画 像処理装置100はベジエ分割装置17の他に制御装置 4'、操作部19、記憶媒体5の一例となるROM4 5、記憶装置の一例となるメインメモリ18などを有し ている。メインメモリ18には例えば3次のベジエ曲線 やベジエ曲面を画像処理するための4×4個の制御点の 座標値A、Bが記憶されている。この制御点の座標値

40

A、Bは外部から書き換え可能になされる。メインメモ リ18の記録内容例については図13において説明をす る。

21

【0081】このメインメモリ18には制御装置4'が 接続されると共に、この制御装置4'には操作部19が 接続されている。この操作部19はメインメモリ18の 読出し制御をするための操作情報D3を入力するように 操作される。制御装置4'では操作情報D3に基づいて メインメモリ18に書込み読出し信号S4を出力する。 メインメモリ18では3次のベジエ曲線やベジエ曲面を 10 画像処理するための4×4個の制御点の座標値A, Bが 書込み読出し信号S4に基づいて図形情報生成部6に読 み出される。

【0082】このメインメモリ18に接続された図形情 報生成部6では、操作情報 D3 に基づいて読み出された 制御点の座標値A、Bに関して、u方向に(n+1]た だし、n ≥ 2]) 個の制御点及び v 方向に (n+1) 個 の制御点を格子状に与え、この格子状の制御点からn次 の曲面図形に係る頂点座標値を生成するようになされ る。この例では3次の曲面図形を表現するための頂点の 座標値が生成される。ととで生成された頂点の座標値は 頂点情報Coutとして後段の処理回路へ出力される。

【0083】もちろん、図形情報生成部6には図4で説 明した線形補間器を有しており、浮動小数点又は固定小 数点で示される、23ビット幅の制御点の座標値A、B と、8ビット幅で0≤t≤1の値をとる補間係数tとに 基づき、制御点間を内分する新たな制御点の座標値に関  $UCA \times (1-t) + B \times t$  を順次演算するようになさ れる。更に、図形情報生成部6では2×2個の新たな制 御点の座標値から頂点のu方向に接線ベクトル及びv方 向に接線ベクトルを抽出するようになされる。

【0084】との図形情報生成部6には演算器7が接続 され、2×2個の新たな制御点の座標値から抽出された 頂点POのu方向の接線ベクトル情報Uinとv方向の接 線ベクトル情報Vinとを入力し、この情報Uinと情報V inの外積を演算してその頂点POの法線ベクトル情報H outを出力するようになされる。

【0085】制御装置4'に接続されたROM45に は、制御点の座標値A,Bの指数部の大きい方に桁を合 わせ、この桁合わせ後の座標値Aと補間係数(1-t) とを乗算すると共に、桁合わせ後の座標値Bと補正係数 tとを乗算し、その後、乗算結果を加算した後の加算値 を浮動小数点で示される所定のビット幅の座標値に正規 化するような制御手順や、頂点P0のu方向の接線ベク トル情報 Uinと v方向の接線ベクトル情報 Vinとを所定 のタイミングで外積を演算して出力するような制御手順 が記述されている。

【0086】続いて、メインメモリ18の記録内容例に ついて説明する。図13はメインメモリ18の記録内容 例を示すイメージ図である。この例では、1 Mバイトの 50 図 1 4 は本発明に係る第2の実施形態としての図形情報

メモリ領域に、その格納アドレス0x0000~0x FFFFFによって指定される番地にプログラム情報。 描画リスト、形状データ、テクスチャデータ ID=1、 及びID=2が記録されている。これらのデータは外部 から転送されたゲームデータや、電子アニメーション用 のデータであってもよい。

【0087】図13に示す記録内容例によれば、n次の ベジエ曲面などを生成するアプリケーション本体、この アプリケーションのサブルーチンなどのモジュール群及 びライブラリ群から成るプログラム情報がメモリ領域の 先頭に記述されている。とのアプリケーションには例え ば、n次のベジエ曲面を生成操作するモードを設定する か、又は他の操作モードを設定するかを選択させるよう なプログラムデータも含まれる。プログラム情報の後に は、1ポリゴンの形状データを複数繋げるための制御命 令(以下でポリゴン描画命令ともいう)などの描画リス トが記述されている。

【0088】この描画リストの後には映像素材情報とな る形状データが記述されている。例えばゲーム情報や広 告情報などを2次元又は3次元映像表示するような動画 データを含むグラフィックモデルデータ群が記述されて いる。動画データはDCT(離散コサイン変換)により 画像圧縮されている。形状データの後には、グラフィッ クテクスチャデータ群が記述されている。テクスチャデ ータは76バイトで1ポリゴンの形状データを構成する ようになされ、この例では三角形と四角形の2つのID を持つテクスチャデータが記述される。テクスチャデー タの内容については図23において説明する。この他に サウンドシーケンスデータ群及びサウンドウェーブデー タ群が記述される場合もある。ユーザーの操作と、サウ ンドシーケンスに応じてサウンドウエーブデータを処理 するためである。

【0089】とのように、本発明に係る実施形態として の第1の画像処理装置100によれば、上述した図形情 報生成装置10の主要部がベジェ分割装置17に応用さ れるので、ソフトウエアに依存するところが少なくな り、n次のベジエ曲線やベジエ曲面を表現する上位所定 ビット幅の頂点POの座標値を用いてハードウエアによ り高速に画像処理を行うことができる。従って、ベジエ 分割装置17を構成する線形補間器を小規模な回路構成 によって実現できるので、高性能かつ低消費電力動作が 可能な画像処理装置100を提供することができる。

【0090】また、本発明に係るROM45によれば、 当該ROM45に記録された制御手順に基づいてベジェ 分割装置17に内蔵される線形補間器を再現性良く制御 できるので、n次のベジエ曲線やベジエ曲面を表現する 上位所定ビット幅の頂点の座標値をハードウエアにより 発生させることができる。

【0091】(2)第2の実施形態

(13)

40

変換装置20の構成例を示すブロック図である。

【0092】この実施形態ではn次の曲面図形を表現す るための頂点情報を多角形情報に並び換える場合にメモ リ制御部を備え、m個の頂点情報を1ライン目のメモリ に書き込むと共に、次のm個の頂点情報を2ライン目の メモリに書き込み、その後、1ライン目のメモリで各々 隣接する2個づつの頂点情報と、2ライン目のメモリで 各々隣接する2個づつの頂点情報とにより形成される (m-1)個の四角形の頂点情報をそのまま、もしく 形の頂点情報を順次読み出すようにして、ソフトウエア に依存することなく、n次のベジエ曲線やベジエ曲面を 表現する頂点情報をハードウエアにより多角形情報に変 換できるようにしたものである。

【0093】図14に示す図形情報変換装置20は、n 次の曲線図形及び曲面図形を表現するための頂点情報C inをライン走査のための多角形(以下でポリゴンともい う)情報に並び換えるものである。この図形情報変換装 置20には少なくとも、2ライン分のメモリ21A、2 1 Bを有した記憶装置21が設けられ、1 ライン毎に頂 20 角形の各々の頂点毎に付加されたクリップ情報を入力 点情報Cinを記憶するようになされる。この記憶装置2 1にはラインメモリ21A,21Bを有したスタックメ モリ21'などを使用するとよい。

【0094】この記憶装置21にはメモリ制御部22が 接続され、当該記憶装置21の書込み読出しを制御する ようになされる。例えば、メモリ制御部22はm個の頂 点情報Cinを1ライン目のメモリ21Aに書き込むと共 に、次のm個の頂点情報Cinを2ライン目のメモリ21 Bに書き込み、その後、1ライン目のメモリ21Aで各 々隣接する2個づつの頂点情報Cinと2ライン目のメモ 30 リ21Bで各々隣接する2個づつの頂点情報Cinとによ り形成される(m-1)個の四角形の頂点情報C inをそ のまま、もしくは、その四角形を斜めに分割した2(m -1)個の三角形の頂点情報Coutを順次読み出すよう になされる。以下で四角形又は三角形の頂点情報を多角 形情報Coutともいう。

【0095】この例では2ライン目のメモリ21Bに書 き込んだm個の頂点情報Cinは、次の第3ライン目に相 当するm個の頂点情報Cinの並び換えに使用するので、 1ライン目のメモリ21Aに順次シフトするようになさ れる。第3ライン目に相当するm個の頂点情報Cinを常 に2ライン目のメモリ21Bに書き込むようにするため

【0096】この例では更に、予め四角形動作モード又 は三角形動作モードのいずれかを選択するための設定情 報D4が入力される。ことで四角形動作モードとは四角 形の頂点情報Cinを生成する図形変換制御をいい、三角 形動作モードとは三角形の頂点情報 Cinを生成する図形 変換制御をいうものとする。例えば、設定情報D4が

「1」のときは、四角形動作モードが選択され、それが 50

「0」のときは三角形動作モードが選択される。多角形 情報Coutは少なくとも、多角形の頂点の座標値、色テ クスチャ情報及びクリップ情報を含むものである。色テ クスチャ情報はn次の曲面図形を表示する背景の色情報 である。クリップ情報は多角形情報Coutに基づいて三 次元映像加工(以下でレンダリングという)処理するか 否かを判断するためのコードであり、多角形の各頂点毎 に付加される。

【0097】ここで、多角形情報Coutによって表現さ は、その四角形を斜めに分割した2(m-1)個の三角 10 れる奥行きを含む表示領域(モニタなどの有効表示領域 に等しい)に関して視認可能な範囲をクリップ領域とし たとき、このクリップ領域から外れる多角形の頂点にク リップ情報「1」が付加され、このクリップ領域内に入 っている多角形の頂点にはクリップ情報「0」が付加さ れる。クリップ情報の付加については図18で説明す

> 【0098】とのメモリ制御部22には判定部23が接 続され、上述のクリップ領域から外れる多角形情報Cou tを判別するようになされる。判定部23では、予め多 し、この多角形の頂点が1つでもクリップ領域内にある 場合には、当該多角形情報Coutをレンダリング処理に 含められる。n次のベジエ曲面などの一部がモニタなど の有効表示領域にかかっていて表示が必要であることに よる。

> 【0099】反対に、この多角形の全ての頂点がクリッ プ領域外にある場合には、当該多角形情報Coutをレン ダリング処理から除外するようになされる。n次のベジ エ曲面などがモニタなどの有効表示領域から外れてしま い、レンダリング処理を施してモニタ画面上に現れない ことによる。この判定部23は三角形情報Coutを判定 する場合には三入力NAND回路や三入力AND回路な どから構成され、四角形情報を判定する場合には四入力 NAND回路や四入力AND回路などから構成される。 NAND回路を使用する場合にはインバータが接続さ れ、入力又は出力論理を反転するようになされる。

> 【0100】図15はm=8における図形情報変換例を 示すイメージ図である。図16A及びBは三角形情報C out及び四角形情報 Cout'の出力例を示すイメージ図で ある。

> 【0101】図15に示すベジエ曲面は8個の頂点情報 Cinを走査ライン毎に同一平面に並べたものである。と の例では、三角形動作モードでm=8の場合に、図16 Aに示す三角形の各頂点が「1,2,9」、「2,9, 10], [2, 3, 10], [3, 10, 11], 「3, 4, 11」・・・の三角形情報Coutがメモリ 制御部22から判定部23へ出力される。もちろん、各 三角形の各頂点毎にクリップ情報「1」又は「0」が付 加される。

【0102】四角形動作モードでm=8の場合に、図1

6 Bに示す四角形の各頂点が「1, 2, 9, 10」、「2, 3, 10, 11」、「3, 4, 11, 12」・・・・の四角形情報Cout がメモリ制御部22から判定部23へ出力される。もちろん、各四角形の各頂点毎にクリップ情報「1」又は「0」が付加される。

【0103】図17は液晶表示モニタなどのクリップ領域例を示す仮想表示空間のイメージ図である。図18はスクリーン座標系xs、ysにおけるクリップ領域CLと4ビットのクリップコードの関係例を示す対応図である。この例では図17に示す仮想表示空間上にスクリー 10ン座標系xs、ys、zsが定義され、奥行きはzs座標に関してZ=±1に入る多角形情報Coutのみをレンダリング処理に移行するようになされる。多角形情報Coutは上述した判別部23で判定される。

【0104】図17に示すクリップ領域CLは、多角形情報Coutによって表現される奥行きを含む表示領域に関してビューポイントから視認可能な範囲を定義したものである。このクリップ領域CLは液晶表示モニタなどの480ライン×640画素の有効表示領域に等しい。このクリップ領域CLから外れる多角形の頂点に予めクリップ情報「1」が付加され、このクリップ領域CL内に入っている多角形の頂点にはクリップ情報「0」が付加される。

【0105】つまり、図18に示す対応図はスクリーン 座標系xs,ysにおいて、仮想表示面を井桁に分割したものである。この図の中央部はクリップ領域CLであり、この領域内に含まれる頂点情報Cinには各多角形の頂点P0毎にクリップ情報の一例となる4ビットのクリップコード「0000」が付加される。また、クリップ領域CLの左上部領域のに含まれる頂点情報Cinには各 30 頂点毎にクリップコード「1001」が付加される。

【0106】同様にして、その上部領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「1000」が付加され、その右上部領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「1010」が付加される。更に、その左横領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「0001」が付加され、その右横領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「0010」が付加される。

【0107】クリップ領域CLの左下部領域のに含まれ 40 る頂点情報Cinには各頂点毎にクリップコード「010 1」が付加され、その下部領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「0100」が付加され、その右下部領域のに含まれる頂点情報Cinには各頂点毎にクリップコード「0110」がそれそれ付加される。これらのクリップコード(クリップ情報)は図形情報生成後の座標変換処理の際に頂点情報Cinに付加される。このクリップ情報を図形情報変換後に判定するようにしたのは、図15で説明したように例えば、ベジエ曲面を同一平面に並べて始めて 変換後の多角形情報Cou 50

tがクリップ領域CLに含まれるか否かが判定できることによる。

【0108】図19はクリップコードによる判定結果例を示すイメージ図である。図19に示す斜線の三角形はレンダリング処理がなされないものであり、白抜きの三角形はレンダリング処理に移行されるものである。

【0109】つまり、図19に示す領域①、③、④及び ⑤のみに含まれる三角形「イ」と、三角形「ハ」~

「ホ」と、領域①、②及び③にかかっているがクリップ 領域CLにかかっていない三角形「ロ」とは判定部23 により「レンダリング処理しない」と判定される。これ らはレンダリング処理をしても液晶表示モニタには表示 されないので、判定部23によって当該三角形情報Cou tを除外するようになされる。

【0110】とれに対して、クリップ領域C上にかかっている三角形「ト」と、領域②及び②~⑧にかかっているものの、クリップ領域C上にその大部分がかかっている三角形「へ」とは判定部23により「レンダリング処理をする」と判別される。クリップ領域C上に一部でも20 かかっている三角形「ト」などは液晶表示モニタの有効表示領域で表示されるからである。

【0111】図20はスクリーン座標系ys, zsにおける奥行きを考慮したクリップ領域CL' と6ビットのクリップコードの関係例を示す対応図である。この例では図20に示す仮想表示空間の奥行きにスクリーン座標系ys、zsが対応され、zs座標に関して $Z=\pm 1$ に入る三角形情報Coutのみをレンダリング処理に移行するようになされる。三角形情報Coutは上述した判別部23で判定される。

【0112】図20に示す対応図はスクリーン座標系ys,zsにおいて、仮想空間を井桁に分割したものである。この対応図の中央部は奥行きを考慮したクリップ領域CL'であり、この領域内に含まれる頂点情報Cinには各三角形の頂点P0毎にクリップ情報の他の一例となる6ビットのクリップコード「0000XX」が付加される。また、クリップ領域CL'の前上部領域®に含まれる頂点情報Cinには各頂点毎にクリップコード「0110XX」が付加される。

【0113】同様にして、クリップ上部領域②'に含まれる頂点情報Cinには各頂点毎にクリップコード「0010XX」が付加され、その後上部領域③'に含まれる頂点情報Cinには各頂点毎にクリップコード「1010XX」が付加される。更に、その前中央領域②'に含まれる頂点情報Cinには各頂点毎にクリップコード「0100XX」が付加され、クリップ領域CLの後中央領域⑤'に含まれる頂点情報Cinには各頂点毎にクリップコード「1000XX」が付加される。

る。とのクリップ情報を図形情報変換後に判定するよう 【0114】クリップ領域CLの前下部領域の に含ま にしたのは、図15で説明したように例えば、ベジエ曲 れる頂点情報Cinには各頂点毎にクリップコード「01 面を同一平面に並べて始めて、変換後の多角形情報Cou 50 01XX」が付加され、クリップ下部領域の に含まれ

る頂点情報Cinには各頂点毎にクリップコード「000 1XX」が付加され、その後下部領域® に含まれる頂点情報Cinには各頂点毎にクリップコード「1001XX」がそれそれ付加される。これらのクリップコード(クリップ情報)は図形情報生成後の座標変換処理の際に頂点情報Cinに付加される。

【0115】続いて、本発明に係る実施形態としての図形情報変換方法について図形情報変換装置20の動作例を説明する。図21は本発明に係る実施形態としての図形情報変換装置20の動作例を示すフローチャートである。

【0116】との例では3次の曲線図形及び曲面図形を表現するための、m=128の頂点情報Cinをライン走査のための三角形情報Coutに並び換える場合を想定する。少なくとも、U-V座標系で3次の曲面図形を表現したとき、その制御点の先端から最終端に至る長さ分(m=128)の頂点情報Cinが書き込める、2ライン分のメモリ領域を展開できるスタックメモリ21′などを準備する。

【0117】との例で頂点情報Cinは多角形の頂点P0 20 の座標値、色テクスチャ情報及びクリップ情報を含むものとし、多角形の各頂点毎に図18で説明したようなクリップコードが付加されているものとする。

【0118】とれを前提にして、図21に示すフローチャートのステップB1で頂点情報Cinに関してポリゴン形状を設定する。ととで、例えば設定情報D4= [0]を設定して三角形動作モードが選択される。その後、ステップB2で128個の頂点情報Cinを1ライン目のメモリ領域に書き込む。

【0119】そして、ステップB3で次の128個の頂 30点情報Cinを2ライン目のメモリ領域に書き込む。その後、予め設定された動作モードに基づいてステップB4で制御を切り換える。この例では三角形動作モードが選択されているので、ステップB5に移行して1ライン目のメモリ領域で各々隣接する2個づつの頂点情報Cinと2ライン目のメモリ領域で各々隣接する2個づつの頂点情報Cinとにより形成される127個の四角形を斜めに分割した254個の三角形の頂点情報Cinを順次読み出すようになされる(図16A参照)。

【0120】なお、予め設定された動作モードが四角形 40動作モードの場合には、ステップB6に移行して1ライン目のメモリ領域と2ライン目のメモリ領域の各々の頂点情報Cinとにより形成される127個の四角形の頂点情報Cinをそのまま順次読み出すようになされる(図16B参照)。

【0121】その後、ステップB7に移行してクリップ 領域CLから外れる三角形情報Coutが判別部23によって判別される。との三角形情報Coutの判別の際に、 図19で説明した三角形「ト」、「へ」のように頂点が 1つでもクリップ領域CL内にある場合には、当該三角 形情報Coutをレンダリング処理に含め、三角形「イ」 ~「ホ」のように、全ての頂点がクリップ領域CL外に ある場合には、当該三角形情報Coutをレンダリング処 理から除外するようになされる。

【0122】そして、ステップB8に移行して、全ての 三角形情報Coutの判別が終了したか否かがチェックさ れる。判別が全部終了していない場合にはステップB2 に戻って上述した処理を繰り返すようになされる。判別 が全部完了した場合には当該図形情報変換処理を終了す 10 る。

【0123】このように、本発明に係る第2の実施形態としての図形情報変換装置20によれば、3次の曲線図形及び曲面図形を表現するための頂点情報Cinを三角形情報Coutに並び換える場合に、1ライン目のメモリ領域と2ライン目のメモリ領域の各々の頂点情報Cinとにより形成される127個の四角形の頂点情報Cinをそのまま、もしくは、その四角形を斜めに分割した254個の三角形の頂点情報Cinを記憶装置21から順次読み出すようになされる。

【0124】従って、ソフトウエアに依存することなく、n次のベジエ曲線やベジエ曲面を表現する頂点情報 Cinをハードウエアにより三角形情報Coutに並び換えることができる。しかも、メモリ21A、21Bといった小規模なメモリ構成によってスタックメモリなどを実現できるので、高性能かつ低消費電力動作が可能な図形情報変換装置20を提供することができる。

【0125】[第2の画像処理装置]図22は本発明に係る実施形態としての第2の画像処理装置200の構成例を示すブロック図である。

【0126】この例では図14で説明した図形情報変換装置の一例となる頂点並換え装置201を備え、図6で説明した第1の画像処理装置100から出力される多角形の頂点P0の法線ベクトルHout及び各々の多角形の頂点情報(テクスチャデータ)Cinを座標変換した後に、ソフトウエアに依存することなくその頂点情報Cinを並び換え、その後、ライン走査のための画像処理をするようにしたものである。

【0127】図22に示す第2の画像処理装置200は、第1の実施形態で生成されたn次の曲面図形を画像処理するものである。この装置200には第1の画像処理装置100が設けられ、n次の曲面図形を表現するための頂点の座標値を生成するようになされる。画像処理装置100には第1の実施形態で説明した図形情報生成装置が使用される。その内部構成例については図1及び図12で説明しているのでその説明を省略する。

【0128】この画像処理装置100にはライティング 処理部25と座標変換&クリップコード付加部24とが 接続されている。ライティング処理部25では図12に 示した演算器(外積)7から得られる頂点P0の法線ベクトル2と、予め設定された光源ベクトルとの内積(c

50

 $\cos\theta$ )を演算して光色を算出するようになされる。例えば、n次のベジエ曲面の頂点P0の法線ベクトルと光源ベクトルとが一致( $\theta$  = 0又は180°)したときに、その頂点P0が一番明るくなうような輝度を演算するようになされる。

【0129】また、座標変換&クリップコード付加部24では、画像処理装置100によるボリゴン描画命令に基づいて頂点P0の座標値がスクリーン座標(映像表示)系の座標値に変換されると共に、図18及び図20で説明したクリップコードが付加される。この例では、頂点情報Cinは76バイトで1ボリゴンの形状データを構成するようになされる(図23参照)。座標変換&クリップコード付加部24には頂点並換え装置201が接続されている。頂点並換え装置201はメモリ制御部22の一例となる書込みスタック22A及び読出しスタック22Bと、スタックメモリ(記憶装置)21、と、クリップ判定器(判定部)23、とを有している。なお、ライティング処理部25の出力は頂点並換え装置201をスルーしてラスタライズ処理部26に至るようになされる。

【0130】スタックメモリ211、には、少なくとも、図14に示したような2ライン分のメモリ21A,21 Bを有して頂点情報C inが記憶される。書込みスタック22 Aでは座標変換されたm個の頂点情報C inを順次スタックメモリ211、01ライン目に書き込むと共に、次のm個の頂点情報C inを2 ライン目に書き込むようになされる。読出しスタック22 Bでは1 ライン目で各々隣接する2 個づつの頂点情報C inと2 ライン目で各々隣接する2 個づつの頂点情報C inと2 ライン目で各々隣接する2 個づつの頂点情報C inと2 ライン目で各々隣接する2 個の四角形を斜めに分割した、図16 で説明したような2 (m-1) 個の三角形情報C outを2 タックメモリ2 1 から順次読み出すようになされる。

【0131】スタック読出し器22Bにはクリップ判定器23 が接続され、図19で説明したようなクリップ領域CLから外れる三角形情報Coutを判定するようになされる。クリップ判定器23 では予め三角形の各々の頂点毎に付加されたクリップコードが入力され、これらのクリップコードの三入力AND論理が演算され、三角形の頂点POが1つでもクリップ領域CL内にある場合には、当該三角形情報Coutをレンダリング処理に含め、これら三角形の全ての頂点がクリップ領域CL外にある場合には、当該三角形情報Coutをレンダリング処理から除外するようになされる。

【0132】上述したライティング処理部25及びクリップ判定器23'にはラスタライズ処理部26が接続され、座標変換後の頂点情報Cinが1ポリゴン毎にラスタライズ処理され、1画素のカラーテクスチャアドレス(U,V)が算出される。スクリーン座標系においてライン走査するためである。

【0133】続いて、図23~図26を参照しながら、

第2の画像処理装置200の動作例について説明をする。図23は1ポリゴン(三角形)の形状データの記録内容例を示すデータフォーマットである。

【0134】この例で図23に示す頂点情報Cinは、図24に示すような三角形の1ポリゴンの形状データを76バイトで構成するようになされる。つまり、1ポリゴンは図24に示す3つの頂点1、2、3を有する三角形により表現され、形状データの先頭には図23に示すテクスチャIDが記述され、その後には、三角形の第1項10点のX、Y、Z座標が各々の記述されると共に、第1頂点のカラー値、テクスチャU、V座標が記述される。

【0135】とれに続いて第2項点のX、Y、Z座標が各々の記述されると共に、第2項点のカラー値、テクスチャU、V座標が記述される。更に、第3項点のX、Y、Z座標が各々の記述されると共に、第3項点のカラー値、テクスチャU、V座標が記述される。これらの頂点情報Cinはユーザーの操作に応じて図16で説明したような三角形状の頂点1,2,3を繋ぎ合わせるように連続される。

20 【0136】この例では、一方で、第1の画像処理装置 100から出力される、n次の曲面図形を表現するため の多角形の頂点P0の法線ベクトルHoutをライティング処理し、他方で各々の多角形の頂点情報Cinを座標変換した後に、ソフトウエアに依存することなく、その頂点情報Cinを並び換え、その後、ライン走査のための画像処理をする場合を想定する。

【0137】つまり、連続された頂点情報Cinは1頂点毎に座標変換される。座標変換後の頂点情報Cinは、図25に示す1ポリゴン毎にラスタライズ処理を行って1画素毎にカラーテクスチャアドレス(U, V)が算出される。その後、テクスチャIDにより指示される頂点情報CinからU, V座標のテクスチャカラーが読み出され、各々の画素のカラー値が決定され、このカラー値に基づいて液晶表示モニタなどに3次元映像画像が表示される。なお、n次の曲面図形の各々の頂点の座標値は第1の画像処理装置100によって生成されるものとする。

【0138】 これを前提にして、図26に示すフローチャートのステップE1で第1の画像処理装置100から座標変換&クリップコード付加部24へ描画リストD2が転送される。その後、座標変換&クリップコード付加部24ではステップE2で描画リストD2に基づいて1頂点毎に頂点情報Cinがスクリーン座標系の座標値に変換される。この座標変換&クリップコード付加部24により座標変換された頂点情報Cinは、上述した頂点並換え装置201により、ライン走査のための三角形情報Coutに並び換えられる。

【0139】そして、ステップE3で1ポリゴン毎にラスタライズ処理部26へ転送される。とのラスタライズ 50 処理部26では、1ピクセル(X,Y)毎の2値、カラ

31

32

\* て、スクリーン座標系のカラー値RGBが(10)式に

-値 (Rf, Gf, Bf)、テクスチャアドレス (U, V) が算出される。その後、U, V座標系のテクスチャカラー値 (Rt, Gt, Bt) が読み出される。そし \*

 $R = R f \times R t$ ,  $G = G f \times G t$ ,  $B = B f \times B t \cdot \cdot \cdot \cdot (10)$ 

より求められる。

【0140】その後、ステップE7に移行して奥行き情報であるZ値が比較される。Z値が図20に示したようにクリップ領域の手前にある場合には三角形情報Coutの書込みを行う。Z値がクリップ領域の後方にある場合には液晶表示モニタに表示されないので、その書込みを行わないようになされる。その後、ステップE9に移行して三角形情報Coutの書込みが全部終了したか否かがチェックされる。全部書込みを終了した場合には、当該画像処理を終了する。当該三角形情報Coutの書込みを全部終了していない場合にはステップE1に戻って上述した処理を繰り返すようになされる。

【0141】とのように、本発明に係る実施形態としての第2の画像処理装置200によれば、ソフトウェアに依存することなく、スタック書込み器22Aによってm個の頂点情報Cinが1ライン目のメモリ領域に書き込まれると共に、次のm個の頂点情報Cinが2ライン目のメモリに書き込まれ、その後、1ライン目のメモリで各々隣接する2個づつの頂点情報Cinと2ライン目のメモリで各々隣接する2個づつの頂点情報Cinと2ライン目のメモリで各々隣接する2個づつの頂点情報Cinとにより形成される(m-1)個の四角形を斜めに分割した2(m-1)個の三角形の頂点情報Cinがスタックメモリ部21、からスタック読出し器22Bにより順次読み出すようになされる。

【0142】これにより、ハードウエアにより並び換えられた三角形情報Coutに基づいてn次のベジエ曲線やベジエ曲面を表現するような画像処理をすることができる。

【0143】しかも、小規模な回路構成によって頂点並換え装置201などを実現できるので、高性能かつ低消費電力動作が可能な画像処理装置200を提供することができる。また、当該画像処理装置200を組み込んだエンタテインメント装置や、携帯端末装置及び携帯電話機などを構成することができる。

【0144】(3) 実施例

図27は本発明に係る実施例としての携帯端末装置30 0の構成例を示すブロック図である。

【0145】この例では上述した第1の画像処理装置100と第2の画像処理装置200とを組み合わせ、情報処理装置の一例となる携帯端末装置300を構成したものである。第1及び第2の実施形態で説明した同じ符号のものは同じ機能を有するためその説明を省略する。

【0146】つまり、図27に示す携帯端末装置300は、図12に示した第1の画像処理装置100と図22に示した第2の画像処理装置200とを1チップ化したLS!回路を主要部と成し、n次の曲面図形を外部操作に基づいて情報処理をするものである。

【0147】図27において、一点鎖線で囲んだ第1の画像処理装置100はベジエ分割装置17、メインメモリ18、操作ボタン39、CPU40、入力コントローラ43及びROM (Read Only Memory) 45などから構成され、二点鎖線で囲んだ第2の画像処理装置200は座標変換&クリップコード付加部24、ライティング処理部25、頂点並換え装置201及びラスタライズ処理部26から構成されている。

【0148】 これらの構成要素の他に携帯端末装置300には、メモリコントローラ27、フレームメモリ28、液晶表示コントローラ(LCDC)29、インタフェース42、サウンドプロセスユニット(以下で単にSPUという)44などが設けられている。この例で波線で囲んだ部分が1チップに集積化されるものである。もちろん、ベジエ分割装置17や、頂点並換え装置201、SPU44などは個別に1Cチップ化して同一プリント基板上に実装してもよい。

【0149】図27に示すバス41にはベジェ分割装置17、メインメモリ18、CPU40、インタフェース42、入力コントローラ43、SPU44及びROM45などが接続されている。ROM45は第1及び第2の実施形態で接続した制御手順や、メインメモリ18、SPU44等の管理を行ういわゆるオペレーティングシステム等のプログラム情報を格納したものである。

【0150】この例で、インタフェース42にはメモリカートリッジ30などが装着されて使用される。メモリカートリッジ30はゲームデータや、電子アニメーションなどの電子コンテンツを記録したものである。メモリカートリッジ30は例えば、バス34を有しており、このバス34にインタフェース31、読出しコントロール用のマスクROM32及びコンテンツ記録用のEEPROM33にはゲームデータなどのプログラム情報や映像素材情報が記録されている。

【0151】 このメモリカートリッジ30の内容はインタフェース42及びバス41を通してメインメモリ18に転送される。メモリカートリッジ30から転送されてきたゲームキャラタの、例えば、第1の実施形態で説明したn次のベジエ曲面やベジエ曲線などを生成するための制御点の座標値が記憶される(図13参照)。メインメモリ18にはランダムアクセスメモリ(RAM:Random Access Memory)からなる。ここでいうメインメモリ18は、そのメモリ上でプログラムを実行できるものをいう。

【0152】このメインメモリ18にはバス41を通し 50 てベジエ分割装置17が接続され、メインメモリ18か

30

33

ら読み出した制御点の座標値に基づいてn次の曲面図形 を画像処理するようになされる。ベジエ分割装置 17は 第1の実施形態で説明した浮動小数点の線形補間器を有 しており、23ビット幅の制御点の座標値A, Bと、8 ビット幅で0≤t≤1の値をとる補間係数tとに基づ き、これらの制御点間を内分する新たな制御点の座標値 に関して $A \times (1 - t) + B \times t$  を順次演算するように なされる。線形補間器の内部構成例及びその機能につい ては図4で説明した通りであるのでその説明を省略す る。これらの制御手順はROM45に記述されており、 アプリケーション実行時にCPU40によって読み出さ れる。

【0153】上述のバス41にはベジエ分割装置17を 制御するために入力コントローラ(INTC)43が接 続され、この入力コントローラ43には操作ボタン39 が装備されている。この操作ボタン39はユーザによっ て操作される。操作ボタン39を操作すると入力コント ローラ43で操作情報D3が発生され、この操作情報D 3はバス41を通してCPU40に入力するようになさ れる。CPU40は操作情報D3に基づいてメインメモ 20 リ18から頂点情報Cinを読み出すと共に、このの頂点 情報Cinに関して、その曲線図形及び曲面図形を変化さ せるような表示制御を実行するようになされる。

【0154】CPU40はROM45に記憶されている オペレーティングシステムを実行することにより、この 携帯端末装置300の全体を制御するもので、例えば、 32ビットのRISC-CPUから成る。そして、この 携帯端末装置300は電源が投入されると、ゲームモー ド又は番組再生モードに応じてCPU40がROM45 に記憶されているオペレーティングシステムを実行する ことにより、CPU40がベジエ分割装置17や、SP U44等の制御を行うようになっている。このCPU4 0は割込み制御を行うので、制御負担を軽減するため に、ダイレクトメモリアクセス(DMA: Direct Memor y Access) 転送用の制御装置を別に設けるようにしても よい。

【0155】このベジエ分割装置17にはライティング 処理部25と座標変換&クリップコード付加部24とが 接続されている。ライティング処理部25ではCPU4 0からの演算要求に応じて、図12に示した演算器(外 積)7から得られる頂点POの法線ベクトルェと、予め 設定された光源ベクトルとの内積( $cos\theta$ )を演算して 光色を算出するようになされる(光源計算)。

【0156】また、座標変換&クリップコード付加部2 4では、ポリゴン描画命令に基づいて頂点P0の座標値 がスクリーン座標(映像表示)系の座標値に変換される と共に、図18及び図20で説明したクリップコードが 頂点情報Cinに付加される。この例でも、頂点情報Cin は76バイトで1ポリゴンの形状データを構成するよう

ード付加部24にはジオメトリトランスファエンジン (GTE: Geometry Transfer Engine) などの並列演算 器が用いられ、CPU40からの演算要求に応じて座標 変換、行列あるいはベクトル等の演算処理が高速に行わ れる。具体的には、この並列演算器により、例えば1つ の三角形状のポリゴンに同じ色で描画するフラットシェ ーディングを行う演算の場合では、1秒間に最大150 万程度のポリゴンの座標演算を行うことができ、これに よって、この携帯端末装置300では、CPU40の負 荷を低減するとともに、高速な座標演算を行うことがで

【0157】この座標変換&クリップコード付加部24 には頂点並換え装置201が接続され、少なくとも、図 14に示したような2ライン分のメモリ21A、21B を有して頂点情報Cinが記憶される。頂点並換え装置2 01にはグラフィックプロセッサユニット(GPU:Gr aphic Processing Unit ) などが使用され、CPU40 からの描画指示に従って頂点並び換えが行われる。頂点 並換え装置201では座標変換されたm個の頂点情報C inを順次1ライン目のメモリ領域に書き込むと共に、次 のm個の頂点情報Cinを2ライン目のメモリ領域に書き 込むようになされる。その後、1ライン目で各々隣接す る2個づつの頂点情報Cinと2ライン目で各々隣接する 2個づつの頂点情報Cinとにより形成されるm-1個の 四角形を斜めに分割した2 (m-1) 個の三角形情報C outを順次読み出すようになされる。

【0158】更に、頂点並換え装置201では図19で 説明したようなクリップ領域CLから外れる三角形情報 Coutを判定するようになされる。三角形の頂点POが 1つでもクリップ領域CL内にある場合には、当該三角 形情報Coutをレンダリング処理に含め、これら三角形 の全ての頂点がクリップ領域CL外にある場合には、当 該三角形情報Coutをレンダリング処理から除外するよ うになされる。

【0159】この頂点並換え装置201にはラスタライ ズ処理部26が接続され、座標変換後の頂点情報Cinが 1ポリゴン毎にラスタライズ処理され、1画素のカラー テクスチャアドレス(U, V)が算出される。このラス タライズ処理部26にはメモリコントローラ27を通し てフレームメモリ28が接続され、このメモリコントロ ーラ27にはLCDC29を通して液晶表示モニタ36 が接続されている。

【0160】メモリコントローラ27ではラスタライズ 処理部26からフレームメモリ28へ液晶表示モニタ3 6の1画面分の表示データが書き込まれる。例えば、メ モリコントローラ27は、CPU40からの描画命令に 従って、フレームメモリ28に対して多角形 (ポリゴ ン)等の描画を行う。このメモリコントローラ27は、 1秒間に最大36万程度のポリゴンの描画を行うことが になされる(図23参照)。との座標変換&クリップコ 50 できるようになっている。さらに、とのフレームメモリ

28は、いわゆるデュアルボートRAMからなり、メモリコントローラ27からの描画処理と、表示のための読み出しとを同時に行うことができるようになっている。【0161】とのフレームメモリ28は、例えば1Mバイトの容量を有し、それぞれ16ビットの、横が1024画素、縦が512画素からなるマトリックスとして扱われる。また、このフレームメモリ28には、映像出力として展開される表示領域の他に、メモリコントローラ27がボリゴン等の描画を行う際に参照するカラールックアップテーブル(CLUT: Color Look Up Table)が記憶されるCLUT領域と、描画時に座標変換されてメモリコントローラ27によって描画されるボリゴン等

の中に挿入(マッピング)される素材(テクスチャ)が

記憶されるテクスチャ領域が設けられている。これらの CLUT領域とテクスチャ領域は、表示領域の変更等に

従って動的に変更されるようになっている。

【0162】なお、とのメモリコントローラ27はラスタライズ処理部26と共に、上述のフラットシェーディングの他にポリゴンの頂点の色から補完してポリゴン内の色を決めるグーローシェーディングと、このテクスチャをポリゴンに張り付けるテクスチャマッピングを行うことができるようになっている。これらのグーローシェーディングまたはテクスチャマッピングを行う場合には、この座標変換&クリップコード付加部24は、1秒間に最大50万程度のポリゴンの座標演算を行うようになされる。 コーザはスラアプリケーションのメールでは、このを引きないできるようにないまたはテクスチャマッピングを行う場合には、この座標変換&クリップコード付加部24は、1秒間に最大50万程度のポリゴンの座標演算を行うようになされる。 出線などを変

【0163】上述のメモリコントローラ27からの表示データはLCDC29で映像出力信号 φνに変換され、この映像出力信号 φνが液晶表示モニタ36に出力される。液晶表示モニタ36では例えば、3次のベジエ曲面から成るゲームキャラクタを3次元表示するようになされる。

【0164】また、SPU44ではCPU40からの指 示に基づいて、ゲームや電子アニメーションに係る音声 情報を再生し増幅などが行われてその音声信号がスピー カー37に出力される。SPU44内に波形データ等を 記録したサウンドバッファなどを設け、楽音、効果音等 を発生するようにしてもよい。サウンドバッファを設け た場合には、SPU44で、例えば16ビットの音声デ ータを4 ビットの差分信号として適応予測符号化(AD 40 PCM: Adaptive Differential PCM ) された音声デー タを再生(ADPCM復号機能)したり、サウンドバッ ファに記憶されている波形データを再生することによ り、効果音等を発生(再生機能)したり、サウンドバッ ファに記憶されている波形データを変調させて再生(変 調機能)することもできるようになる。このような機能 を備えることによって、このSPU44は、CPU40 からの指示によって記録された波形データに基づいて楽 音、効果音等を発生するいわゆるサンプリング音源とし て使用することができる。

【0165】続いて、携帯端末装置300の動作例について説明をする。図28は携帯端末装置300における処理例を示すフローチャートである。この例では、ゲーム用のメモリカートリッジ30を装着してゲームモードを実行することを想定する。ゲームデータには3次のベジエ曲面により構成されるキャラクタが準備され、ベジエ分割装置17では線形補間器により制御点の座標値が分割され、頂点並換え装置では三角形動作モードにより頂点情報Cinが並び換えられることを前提とする。

【0166】これを前提にして、図28のフローチャートのステップF1でユーザは当該携帯端末装置300にメモリカートリッジ30を装着した後に、ステップF2で電源をオンする。ここで電源が投入されると、CPU40がROM45に記憶されているオペレーティングシステムを実行することにより、ベジエ分割装置17や、SPU44等の制御を行うようになされる。この例ではユーザはステップF3でゲームモードを選択する。このアプリケーション実行時にCPU40によってROM45から第1及び第2の実施形態で説明した制御手順が読み出される。

【0167】そして、一方で、ユーザはステップF4で操作ボタン39を操作する。操作ボタン39が操作されると、入力コントローラ43及びバス41を通してCPU40に操作情報D3が入力される。この操作情報D3はゲームキャラタを構成する3次のベジエ曲面やベジエ曲線などを変形させたり、キャラクタを移動させたりするために使用される。

【0168】この操作情報D3の入力に並行して、CPU40はステップF5~ステップF10で操作情報D3に基づいてメインメモリ18から頂点情報Cinを読み出すと共に、この頂点情報Cinに関して、その3次の曲線図形及び曲面図形を変化させるような表示制御を実行するようになされる。

【0169】つまり、ステップF5ではメモリカートリッジ30からプログラム情報及び映像素材情報から成るゲームデータが読み出され、メインメモリ18に転送される。この映像素材情報には、ゲームキャラタを構成する3次のベジエ曲面やベジエ曲線などを生成するための制御点の座標値が含まれている(図13参照)。

【0170】このゲームデータがメインメモリ18に転送されると、ステップF6に移行してベジエ分割装置17では操作情報D3に基づいてメインメモリ18から読み出した制御点の座標値に基づいて3次の曲面図形を画像処理するようになされる。例えば、ベジエ分割装置17の浮動小数点の線形補間器により、23ビット幅の制御点の座標値A,Bと、8ビット幅で0≦t≦1の値をとる補間係数tとに基づき、これらの制御点間を内分する新たな制御点の座標値に関してA×(1-t)+B×tを順次演算するようになされる。

50 【0171】そして、ステップF7ではCPU40から

のポリゴン描画命令に基づいて頂点POの座標値が座標 変換&クリップコード付加部24により、スクリーン座 標(映像表示)系の座標値に変換されると共に、図18 及び図20で説明したクリップコードが頂点情報Cink

【0172】 これに並行してステップF8ではCPU4 ①からの演算要求に応じてライティング処理部25によ POの法線ベクトルzと、予め設定された光源ベクトル との内積( $\cos heta$ )を演算して光色を算出するようにな される(光源計算)。

付加される。例えば、フラットシェーディングの場合

行われる。

に、1秒間に最大150万程度のポリゴンの座標演算が

【0173】その後、ステップF9に移行してCPU4 0からの描画命令に応じて頂点並換え装置201では、 座標変換されたm個の頂点情報 Cinを順次 1 ライン目の メモリ領域に書き込むと共に、次のm個の頂点情報Cin を2ライン目のメモリ領域に書き込むようになされる。 その後、1ライン目で各々隣接する2個づつの頂点情報 Cinと2ライン目で各々隣接する2個づつの頂点情報C inとにより形成されるm-1個の四角形を斜めに分割し た2(m-1)個の三角形情報Coutを順次読み出すよ うになされる。

【0174】更に、頂点並換え装置201では図19で 説明したようなクリップ領域CLから外れる三角形情報 Coutを判定するようになされる。三角形の頂点POが 1つでもクリップ領域CL内にある場合には、当該三角 形情報Coutをレンダリング処理に含め、これら三角形 の全ての頂点がクリップ領域CL外にある場合には、当 該三角形情報Coutをレンダリング処理から除外するよ うになされる。

【0175】その後、ステップF10では座標変換後の 頂点情報Cinがラスタライズ処理部26により、1ポリ ゴン毎にラスタライズ処理され、1画素のカラーテクス チャアドレス(U, V)が算出される。そして、ステッ プF11に移行してメモリコントローラ27ではラスタ ライズ処理部26からフレームメモリ28へ液晶表示モ ニタ36の1画面分の表示データが書き込まれる。例え ば、メモリコントローラ27は、CPU40からの描画 命令に従って、フレームメモリ28に対して1秒間に最 40 大36万程度のポリゴンの多角形 (ポリゴン)等の描画 が行われる。

【0176】とこで、メモリコントローラ27がポリゴ ン等の描画を行う際に、テクスチャ領域やカラールック アップテーブルなどが参照され、フラットシェーディン グ処理、グーローシェーディング処理、テクスチャマッ ピング処理等を行うようになされる。この映像表示処理 による表示データはLCDC29で映像出力信号 φ v に 変換され、との映像出力信号φνが液晶表示モニタ36 に出力される。液晶表示モニタ36では例えば、3次の

ベジエ曲面から成るゲームキャラクタを3次元表示する ようになされる。この映像表示処理に伴う音声情報はC PU40からの指示に基づいて、SPU44により再生 され増幅され、その音声信号がスピーカー37に出力さ れる。これにより、ユーザは携帯端末装置300でゲー ムを楽しむことができる。

【0177】なお、ゲームが終わると、ステップF12 に移行してゲームモードを終了するか否かがCPU40 により判断される。ゲームモードを終了する場合には、 り、図12に示した演算器(外積)7から得られる頂点 10 電源オフ情報などがCPU40により検出されるので、 これらの情報処理を終了する。ユーザがゲームモードの 繰り返しなどを操作ボタン39を操作してCPU40に 指示した場合には、ステップF4及びステップF5に戻 って、上述したステップF4~ステップF11が繰り返 される。これにより、ユーザは携帯端末装置300で何 度もゲームを楽しむことができる。

> 【0178】このように、本発明に係る実施例としての - 携帯端末装置300によれば、第1及び第2の画像処理 装置100、200が応用されるので、ソフトウェアに 20 依存することなく、外部からの操作情報 D3とハードウ エアにより処理された三角形情報Coutとに基づいてゲ ームキャラクタなどのベジエ曲面を高速に情報処理する ことができる。

> 【0179】このベジエ曲面を小規模なハードウエアに よって処理することができるだけではなく、同時に後段 のライティング処理部25で必要な法線ベクトルも算出 することができる。また、クリップ判定を頂点並び換え と同時に簡単に行うことができ、クリップ領域CLに一 部でも入る可能性のない三角形情報Coutを除去でき 30 る。

【0180】従って、無駄な三角形情報Coutをレンダ リング処理しなくても済み、当該携帯端末装置300の 性能を向上させることができる。これにより、今まで、 曲面処理が困難であった携帯端末装置300等でベジェ 曲面処理を導入することができる。

【0181】しかも、ベジエ分割装置17を構成する線 形補間器を小規模な回路構成によって実現できるし、小 規模なメモリ構成によって頂点並換え装置201を実現 できる。従って、高性能かつ低消費電力動作が可能な携 帯端末装置300や、ゲーム機能付きの携帯電話機を提 供することができる。

【0182】また、本実施例に係るROM45によれ ば、ベジエ分割装置17や頂点並換え装置201を制御 手順に基づいてタイミング良く制御できるので、n次の 曲面図形を全てハードウエアで処理・描画することが可 能となる。ソフトウエアによるオーバーヘッドが無くな るので、非常に高性能な携帯端末装置300を構成する ことができる。

[0183]

【発明の効果】以上説明したように、本発明に係る図形

情報生成装置によれば、水平方向に(n+1)個の制御点及び垂直方向に(n+1)個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現する場合に、その曲面図形の頂点の座標値を生成する線形補間器を備え、所定のビット幅の制御点の座標値A.B と、所定のビット幅で $0 \le t \le 1$ の値をとる補間係数 t とに基づき、制御点間を内分する新たな制御点の座標値に関して $A \times (1-t) + B \times t$  を順次演算するものである。

39

【0184】この構成によって、ソフトウエアに依存することなく、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値をハードウエアにより得ることができる。しかも、小規模な回路構成によって線形補間器を実現できるので、高性能かつ低消費電力動作が可能な図形情報生成装置を提供することができる。

【0185】本発明に係る画像処理装置によれば、上述した図形情報生成装置が応用されるので、ソフトウエアに依存することなく、ハードウエアにより生成された上位所定ビット幅の頂点の座標値を用いてn次のベジエ曲線やベジエ曲面を表現するような画像処理を行うことが 20できる。

【0186】この構成によって、図形情報生成装置内の 線形補間器を小規模な回路構成によって実現できるの で、高性能かつ低消費電力動作が可能な画像処理装置を 提供することができる。

【0187】本発明に係る情報処理装置によれば、上述した画像処理装置が応用されるので、ソフトウエアに依存することなく、ハードウエアにより生成された上位所定ピット幅の頂点の座標値を外部からの操作情報に基づいてn次のベジエ曲線やベジエ曲面を表現するような情報処理をすることができる。

【0188】従って、画像処理装置を構成する線形補間 器を小規模な回路構成によって実現できるので、高性能 かつ低消費電力動作が可能な、特に携帯端末装置などの 情報処理装置を提供することができる。

【0189】本発明に係る図形情報生成方法によれば、水平方向に(n+1)個の制御点及び垂直方向に(n+1)個の制御点を格子状に与え、この格子状の制御点から n 次の曲面図形を表現するための頂点の座標値を生成する際に、所定のビット幅の  $(n+1) \times (n+1)$  個の制御点の座標値と、所定のビット幅で  $0 \le t \le 1$  の値をとる補間係数  $t \ge t \ge 1$  のが、それぞれ  $t \ge t \ge 1$  のを標値を求め、最終的に  $t \ge t \ge 1$  の一で隣接する名々2 つの制御点間について、それぞれ  $t \ge t \ge 1$  の一で関接する名々2 つの制御点間について、それぞれ  $t \ge 1$  の下で関接する名々2 つの制御点間について、それぞれ  $t \ge 1$  の下で関係を求め、最終的に  $t \ge 1$  を収め、最終的に  $t \ge 1$  の一を標値を求め、その

直方向に関してそれぞれA×(1-t)+B×tを順次 演算し、この頂点の座標値を求めるようになされる。

【0190】この構成によって、ソフトウエアに依存することなく、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値をハードウエアによって得ることができる。しかも、この方法によって実現される図形情報生成装置や、画像処理装置、情報処理装置などにおいて、小規模な回路構成にまとめられた線形補間器を使用することができる。

10 【 0 1 9 1 】本発明に係る記録媒体によれば、水平方向に(n+1)個の制御点及び垂直方向に(n+1)個の制御点を格子状に与え、この格子状の制御点からn次の曲面図形を表現する場合に、その曲面図形の頂点P0の座標値を生成する制御手順が記述されて成るものである。

【0192】この構成によって、図形情報生成装置や、画像処理装置、情報処理装置などに内蔵される線形補間器を記録媒体に記録された制御手順に基づいて再現性良く制御できるので、n次のベジエ曲線やベジエ曲面を表現する上位所定ビット幅の頂点の座標値をハードウエアにより発生させることができる。

【0193】この発明は、ベジエ曲線やベジエ曲面などの図形情報を取り扱うCAD及びCAMシステムを導入したエンタテインメント装置や、携帯用ゲーム機、携帯端末装置及び携帯電話機などに適用して極めて好適である。

【図面の簡単な説明】

30

【図1】本発明に係る第1の実施形態としての図形情報 生成装置10の構成例を示すブロック図である。

【図2】頂点の座標値生成時の(n+1)×(n+1) 個の制御点p0~pn(n+2)の配置例を示す図である。

【図3】浮動小数点による座標値のデータフォーマット 例を示す図である。

【図4】線形補間器1の内部構成例を示すブロック図である。

【図5】U-V座標系における $4\times4$ 個の制御点 $p0\sim$ p15の配置例を示す図である。

【図6】3次のベジエ曲面の図形例を示すイメージ図で40 ある。

【図7】A及びBは3次のベジエ曲面図形の頂点の座標値の生成例(その1)を示す遷移図である。

【図8】A及びBは3次のベジエ曲面図形の頂点の座標値の生成例(その2)を示す遷移図である。

【図9】A~Cは3次のベジェ曲面図形の頂点の座標値の生成例(その3)を示す遷移図である。

【図10】図形情報生成装置10における動作例を示すフローチャートである。

【図11】A~Cは3次のベジェ曲面図形の頂点POの 法線ベクトルの生成例を示す遷移図である。

【図12】本発明に係る実施形態としての第1の画像処理装置100の構成例を示すブロック図である。

【図 1 3 】メインメモリ 1 8 の記録内容例を示すイメージ図である。

【図14】本発明に係る第2の実施形態としての図形情報変換装置20の構成例を示すブロック図である。

【図 1 5 】 m = 8 における図形情報変換例を示すイメージ図である。

【図16】A及びBは三角形情報Cout及び四角形情報Cout'の出力例を示すイメージ図である。

【図17】液晶表示モニタなどのクリップ領域例を示す 仮想表示空間のイメージ図である。

【図18】スクリーン座標系xs,ysにおけるクリップ領域と4ビットのクリップコードの関係例を示す対応図である。

【図19】クリップコードによる判定結果例を示すイメ ージ図である。

【図20】スクリーン座標系ys,zsにおけるクリップ領域と奥行きコードを含めた6ビットのクリップコードの関係例を示す対応図である。

【図21】本発明に係る実施形態としての図形情報変換 装置20における動作例を示すフローチャートである。

【図22】本発明に係る実施形態としての第2の画像処理装置200の構成例を示すブロック図である。

【図23】1ポリゴン (三角形) の形状データの記録内容例を示すデータフォーマットである。

【図24】三角形状のポリゴンの構成例を示すイメージ 図である。

【図25】三角形情報Coutのラスタライズ処理例を示すイメージ図である。

【図26】第2の画像処理装置200における処理例を 示すフローチャートである。 \*\* \*【図27】本発明に係る実施例としての携帯端末装置3 00の構成例を示すブロック図である。

42

【図28】携帯端末装置300における処理例を示すフローチャートである。

【図29】従来例に係る3次のベジエ曲線の例 (その1)を示す図である。

【図30】3次のベジエ曲線の例(その2)を示す図である。

【図31】3次のベジエ曲面の例(その1)を示す図で 10 ある。

【図32】3次のベジエ曲面の例(その2)を示す図である。

【符号の説明】

1···線形補間器、2,21A,21B···メモリ 部、21'・・・スタックメモリ、3・・・制御点選択 部、4,4'・・・制御装置、5・・・記録媒体、5' ···ROM(記録媒体)、6···図形情報生成部、 7・・・演算器、10・・・図形情報生成装置、11・ ・・桁合わせ部、12, 13・・・乗算器、14・・・ 20 減算器、15・・・加算器、16・・・正規化部、17 ・・・ベジエ分割装置、18・・・メインメモリ、19 ・・・操作部、20・・・図形情報変換装置、21・・ ・記憶装置、22・・・メモリ制御部、22A・・・ス タック書込み器、22B・・・スタック読出し器、23 ・・・判定部、23'・・・クリップ判定器、24・・ ・座標変換&クリップコード付加部、25・・・ライテ ィング処理部、26・・・ラスタライズ処理部、30・ ・・メモリカートリッジ、36・・・液晶表示モニタ、 100・・・第1の画像処理装置、200・・・第2の 画像処理装置、300 · · · 携帯端末装置 (情報処理装 30

【図3】

[図5]

# 座標値のデータフォーマット例 4×4個の制御点P0~P15の配置例

置)





【図1】

#### 第1の実施形態としての図形情報生成装置 10の構成例



【図4】

#### 線形補間器1の内部構成例



【図2】

# 制御点 P0~ Pn(n+2) の配置例



【図6】

# 3次のベジエ曲線の例



【図24】

# 三角形状のポリゴンの構成例



【図7】

# 頂点の座標値の生成例(その1)

#### 【図8】

#### 頂点の座標値の生成例 (その2)





#### 【図12】

pu11

#### 第1の画像処理装置100の構成例

pu10

pu9 O



#### 【図15】

# m=8における図形情報変換例



【図9】

#### 【図10】

#### 頂点の座標値の生成例 (その3)

### 図形情報生成装置10における動作例









【図16】

【図18】

# 三角形情報 Cout 及び四角形情報 Cout'の出力例





### クリップ領域と4ビットクリップコード の関係例



【図11】

【図13】

#### 法線ベクトルの生成例

### メインメモリ18の記録内容例



【図19】

【図20】

# クリップコードによる判定結果例 奥行きコードを含めた6ビットのクリップ コードの例



【図14】

【図17】

第2の実施形態としての図形情報変換装置 液晶表示モニタなどのクリップ領域例 20の構成例



【図25】

【図29】

# 三角形情報 Coutのラスタライズ処理例 3 次ベジエ曲線の例(その 1)





【図21】

#### 図形情報変換装置20における動作例



【図22】

#### 第2の画像処理装置200の構成例



[図30]

# 3次ベジエ曲線の例(その2)

#### 【図31】

# 3次ベジエ曲面の例(その1)





【図23】

1ポリゴン(三角形)の形状データ の記録内容例



【図26】

# 画像処理装置200における処理例



【図32】

## 3次ベジェ曲面の例(その2)



【図27】

【図28】

#### 携帯端末装置300の構成例

### 携帯端末装置300における処理例

